feat(cloud): support multiple user accounts (#1382)

Co-authored-by: V <vendicated@riseup.net>
This commit is contained in:
Lewis Crichton 2023-07-08 02:36:59 +01:00 committed by GitHub
parent 7cd1d4c60f
commit e52ae62441
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -28,15 +28,39 @@ import { openModal } from "./modal";
export const cloudLogger = new Logger("Cloud", "#39b7e0"); export const cloudLogger = new Logger("Cloud", "#39b7e0");
export const getCloudUrl = () => new URL(Settings.cloud.url); export const getCloudUrl = () => new URL(Settings.cloud.url);
const cloudUrlOrigin = () => getCloudUrl().origin;
const getUserId = () => {
const id = UserStore.getCurrentUser()?.id;
if (!id) throw new Error("User not yet logged in");
return id;
};
export async function getAuthorization() { export async function getAuthorization() {
const secrets = await DataStore.get<Record<string, string>>("Vencord_cloudSecret") ?? {}; const secrets = await DataStore.get<Record<string, string>>("Vencord_cloudSecret") ?? {};
return secrets[getCloudUrl().origin];
const origin = cloudUrlOrigin();
// we need to migrate from the old format here
if (secrets[origin]) {
await DataStore.update<Record<string, string>>("Vencord_cloudSecret", secrets => {
secrets ??= {};
// use the current user ID
secrets[`${origin}:${getUserId()}`] = secrets[origin];
delete secrets[origin];
return secrets;
});
// since this doesn't update the original object, we'll early return the existing authorization
return secrets[origin];
}
return secrets[`${origin}:${getUserId()}`];
} }
async function setAuthorization(secret: string) { async function setAuthorization(secret: string) {
await DataStore.update<Record<string, string>>("Vencord_cloudSecret", secrets => { await DataStore.update<Record<string, string>>("Vencord_cloudSecret", secrets => {
secrets ??= {}; secrets ??= {};
secrets[getCloudUrl().origin] = secret; secrets[`${cloudUrlOrigin()}:${getUserId()}`] = secret;
return secrets; return secrets;
}); });
} }
@ -44,7 +68,7 @@ async function setAuthorization(secret: string) {
export async function deauthorizeCloud() { export async function deauthorizeCloud() {
await DataStore.update<Record<string, string>>("Vencord_cloudSecret", secrets => { await DataStore.update<Record<string, string>>("Vencord_cloudSecret", secrets => {
secrets ??= {}; secrets ??= {};
delete secrets[getCloudUrl().origin]; delete secrets[`${cloudUrlOrigin()}:${getUserId()}`];
return secrets; return secrets;
}); });
} }
@ -117,8 +141,7 @@ export async function authorizeCloud() {
} }
export async function getCloudAuth() { export async function getCloudAuth() {
const userId = UserStore.getCurrentUser().id;
const secret = await getAuthorization(); const secret = await getAuthorization();
return window.btoa(`${secret}:${userId}`); return window.btoa(`${secret}:${getUserId()}`);
} }