diff --git a/README.md b/README.md index fb3996c..44ff7b4 100644 --- a/README.md +++ b/README.md @@ -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) diff --git a/manifest.json b/manifest.json index 7e536b6..ded809a 100644 --- a/manifest.json +++ b/manifest.json @@ -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", diff --git a/src/index.ts b/src/index.ts index 8d53764..0fcddb5 100644 --- a/src/index.ts +++ b/src/index.ts @@ -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 => { diff --git a/src/lib/requiredModules.ts b/src/lib/requiredModules.ts index b0e4115..240293b 100644 --- a/src/lib/requiredModules.ts +++ b/src/lib/requiredModules.ts @@ -4,10 +4,22 @@ import Types from "../types"; export const Modules: Types.Modules = {}; Modules.loadModules = async (): Promise => { - Modules.ElementParser ??= await webpack.waitForProps( - "sanitizeUrl", - "sanitizeText", - ); + Modules.ElementParser ??= await webpack + .waitForProps(["sanitizeUrl", "sanitizeText"], { + timeout: 10000, + }) + .catch(() => { + throw new Error("Failed To Find ElementParser Module"); + }); + + Modules.ConnectedAccountsUtils ??= await webpack + .waitForProps(["setShowActivity", "refreshAccessToken"], { + timeout: 10000, + }) + .catch(() => { + throw new Error("Failed To Find ConnectedAccountsUtils Module"); + }); + Modules.ConnectedAccountsStore ??= webpack.getByStoreName("ConnectedAccountsStore"); Modules.SpotifyStore ??= webpack.getByStoreName("SpotifyStore"); diff --git a/src/lib/utils.tsx b/src/lib/utils.tsx index 848c491..8edcb6b 100644 --- a/src/lib/utils.tsx +++ b/src/lib/utils.tsx @@ -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(() => { @@ -56,7 +54,7 @@ export const error = async (res): Promise => { return new Error("Unknown Error, Check the console and report the dev"); } }; -export const play = async (type: string, id: string): Promise => { +export const play = async (type: string, id: string, retry?: boolean): Promise => { const { socket, device } = await ensureSpotifyPlayer(); if (!socket?.accessToken) { throw new Error("Please link your Spotify to Discord in Settings > Connections"); @@ -77,10 +75,20 @@ export const play = async (type: string, id: string): Promise => { 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 => { +export const queue = async (type: string, id: string, retry?: boolean): Promise => { const { socket, device } = await ensureSpotifyPlayer(); if (!socket?.accessToken) { throw new Error("Please link your Spotify to Discord in Settings > Connections"); @@ -100,6 +108,15 @@ export const queue = async (type: string, id: string): Promise => { 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); }; diff --git a/src/types.ts b/src/types.ts index 6f14461..3d9d072 100644 --- a/src/types.ts +++ b/src/types.ts @@ -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; @@ -114,6 +132,7 @@ export namespace Types { export interface Modules { loadModules?: () => Promise; ConnectedAccountsStore?: ConnectedAccountsStore; + ConnectedAccountsUtils?: ConnectedAccountsUtils; ElementParser?: ElementParser; SpotifyStore?: SpotifyStore; }