Skip to content

Commit

Permalink
swc
Browse files Browse the repository at this point in the history
  • Loading branch information
yofukashino committed Jun 25, 2024
1 parent a7926db commit b428b80
Show file tree
Hide file tree
Showing 6 changed files with 70 additions and 22 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,10 @@ Make your experience better with spotify links.
Like Playing directly or adding in queue. (Also opening directly in app)

Direct Download Link:
[![dev.yofukashino.Distify.asar](https://img.shields.io/github/downloads/YofukashiNo/MessageLinkEmbeds/total.svg?style=social&label=Direct%20Download)](https://github.com/YofukashiNo/Distify/releases/latest/download/dev.yofukashino.Distify.asar)
[![dev.yofukashino.Distify.asar](https://img.shields.io/github/downloads/YofukashiNo/Distify/total.svg?style=social&label=Direct%20Download)](https://github.com/YofukashiNo/Distify/releases/latest/download/dev.yofukashino.Distify.asar)

Install Link:
[![Safe](https://img.shields.io/github/downloads/YofukashiNo/MessageLinkEmbeds/total.svg?style=social&label=Install%20in%20Replugged&logo=)](https://replugged.dev/install?identifier=YofukashiNo/Distify&source=github)
[![Safe](https://img.shields.io/github/downloads/YofukashiNo/Distify/total.svg?style=social&label=Install%20in%20Replugged&logo=)](https://replugged.dev/install?identifier=YofukashiNo/Distify&source=github)

![distify](https://i.imgur.com/i7r0j9L.png)

Expand Down
4 changes: 2 additions & 2 deletions manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@
},
"version": "1.0.5",
"updater": {
"type": "store",
"id": "dev.yofukashino.Distify"
"type": "github",
"id": "YofukashiNo/Distify"
},
"license": "MIT",
"type": "replugged-plugin",
Expand Down
4 changes: 2 additions & 2 deletions src/index.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { Injector, Logger } from "replugged";
export const PluginLogger = Logger.plugin("Distify");
export const PluginLogger = Logger.plugin("Distify", "#b380ff");
export const PluginInjector = new Injector();
export const { utils: PluginInjectorUtils } = PluginInjector;
import Injections from "./injections/index";

export const start = (): void => {
void Injections.applyInjections();
void Injections.applyInjections().catch((err) => PluginLogger.error(err));
};

export const stop = (): void => {
Expand Down
20 changes: 16 additions & 4 deletions src/lib/requiredModules.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,22 @@ import Types from "../types";
export const Modules: Types.Modules = {};

Modules.loadModules = async (): Promise<void> => {
Modules.ElementParser ??= await webpack.waitForProps<Types.ElementParser>(
"sanitizeUrl",
"sanitizeText",
);
Modules.ElementParser ??= await webpack
.waitForProps<Types.ElementParser>(["sanitizeUrl", "sanitizeText"], {
timeout: 10000,
})
.catch(() => {
throw new Error("Failed To Find ElementParser Module");
});

Modules.ConnectedAccountsUtils ??= await webpack
.waitForProps<Types.ConnectedAccountsUtils>(["setShowActivity", "refreshAccessToken"], {
timeout: 10000,
})
.catch(() => {
throw new Error("Failed To Find ConnectedAccountsUtils Module");
});

Modules.ConnectedAccountsStore ??=
webpack.getByStoreName<Types.ConnectedAccountsStore>("ConnectedAccountsStore");
Modules.SpotifyStore ??= webpack.getByStoreName<Types.SpotifyStore>("SpotifyStore");
Expand Down
41 changes: 29 additions & 12 deletions src/lib/utils.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,23 +15,21 @@ export const ensureSpotifyPlayer = (): Promise<{
if (activePlayer) return Promise.resolve(activePlayer);
const playableDevices = SpotifyStore.getPlayableComputerDevices();
if (playableDevices.length > 0) {
const [{ socket, device }] = playableDevices;
return Promise.resolve({
socket,
device,
});
const playablePlayer = playableDevices.find(
({ socket, device }) => socket?.connected && device?.is_active != null,
);
return Promise.resolve(playablePlayer ?? {});
}
return new Promise((res) => {
const timer = { timeout: null };
const changeListerner = () => {
const playableDevices = SpotifyStore.getPlayableComputerDevices();
const [{ socket, device }] = playableDevices;
const playablePlayer = playableDevices.find(
({ socket, device }) => socket?.connected && device?.is_active != null,
);
clearTimeout(timer?.timeout);
SpotifyStore.removeChangeListener(changeListerner);
res({
socket,
device,
});
res(playablePlayer ?? {});
};
SpotifyStore.addChangeListener(changeListerner);
timer.timeout = setTimeout(() => {
Expand All @@ -56,7 +54,7 @@ export const error = async (res): Promise<Error> => {
return new Error("Unknown Error, Check the console and report the dev");
}
};
export const play = async (type: string, id: string): Promise<void> => {
export const play = async (type: string, id: string, retry?: boolean): Promise<void> => {
const { socket, device } = await ensureSpotifyPlayer();
if (!socket?.accessToken) {
throw new Error("Please link your Spotify to Discord in Settings > Connections");
Expand All @@ -77,10 +75,20 @@ export const play = async (type: string, id: string): Promise<void> => {
if (SpotifyResponse.ok) {
return;
}
if (!retry) {
const accecssToken = (await Modules.ConnectedAccountsUtils.refreshAccessToken(
"spotify",
socket?.accountId,
)) as string;
if (socket.accessToken !== accecssToken) socket.accessToken = accecssToken;
play(type, id, true);
return;
}

throw await error(SpotifyResponse);
};

export const queue = async (type: string, id: string): Promise<void> => {
export const queue = async (type: string, id: string, retry?: boolean): Promise<void> => {
const { socket, device } = await ensureSpotifyPlayer();
if (!socket?.accessToken) {
throw new Error("Please link your Spotify to Discord in Settings > Connections");
Expand All @@ -100,6 +108,15 @@ export const queue = async (type: string, id: string): Promise<void> => {
if (SpotifyResponse.ok) {
return;
}
if (!retry) {
const accecssToken = (await Modules.ConnectedAccountsUtils.refreshAccessToken(
"spotify",
socket?.accountId,
)) as string;
if (socket.accessToken !== accecssToken) socket.accessToken = accecssToken;
queue(type, id, true);
return;
}
throw await error(SpotifyResponse);
};

Expand Down
19 changes: 19 additions & 0 deletions src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,24 @@ export namespace Types {
shouldShowActivity: DefaultTypes.AnyFunction;
wasAutoPaused: DefaultTypes.AnyFunction;
}
export interface ConnectedAccountsUtils {
authorize: DefaultTypes.AnyFunction;
callback: DefaultTypes.AnyFunction;
completeTwoWayLink: DefaultTypes.AnyFunction;
connect: DefaultTypes.AnyFunction;
disconnect: DefaultTypes.AnyFunction;
fetch: DefaultTypes.AnyFunction;
joinServer: DefaultTypes.AnyFunction;
linkDispatchAuthCallback: DefaultTypes.AnyFunction;
refresh: DefaultTypes.AnyFunction;
refreshAccessToken: DefaultTypes.AnyFunction;
setFriendSync: DefaultTypes.AnyFunction;
setMetadataVisibility: DefaultTypes.AnyFunction;
setShowActivity: DefaultTypes.AnyFunction;
setVisibility: DefaultTypes.AnyFunction;
submitPinCode: DefaultTypes.AnyFunction;
update: DefaultTypes.AnyFunction;
}
export interface SpotifySocket {
accessToken: string;
accountId: string;
Expand Down Expand Up @@ -114,6 +132,7 @@ export namespace Types {
export interface Modules {
loadModules?: () => Promise<void>;
ConnectedAccountsStore?: ConnectedAccountsStore;
ConnectedAccountsUtils?: ConnectedAccountsUtils;
ElementParser?: ElementParser;
SpotifyStore?: SpotifyStore;
}
Expand Down

0 comments on commit b428b80

Please sign in to comment.