Move redirect uri generation to getRedirectUri function of Connection class.
Use api_endpointPublic instead of cdn_endpointPublic
This commit is contained in:
parent
9d5c5a8292
commit
c7277efbad
5
package-lock.json
generated
5
package-lock.json
generated
@ -14178,6 +14178,11 @@
|
||||
"resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
|
||||
"integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ=="
|
||||
},
|
||||
"wretch": {
|
||||
"version": "2.3.2",
|
||||
"resolved": "https://registry.npmjs.org/wretch/-/wretch-2.3.2.tgz",
|
||||
"integrity": "sha512-brN97Z2Mwed+w5z+keYI1u5OwWhPIaW0sJi9CxtKBVxLc3aqP6j1+2FCoIskM7WJq6SUHdxTFx20ox0iDLa0mQ=="
|
||||
},
|
||||
"ws": {
|
||||
"version": "8.11.0",
|
||||
"resolved": "https://registry.npmjs.org/ws/-/ws-8.11.0.tgz",
|
||||
|
@ -3,7 +3,7 @@ import {
|
||||
ConnectedAccount,
|
||||
ConnectionUpdateSchema,
|
||||
DiscordApiErrors,
|
||||
emitEvent
|
||||
emitEvent,
|
||||
} from "@fosscord/util";
|
||||
import { Request, Response, Router } from "express";
|
||||
const router = Router();
|
||||
@ -38,10 +38,12 @@ router.patch(
|
||||
if (!connection) return DiscordApiErrors.UNKNOWN_CONNECTION;
|
||||
// TODO: do we need to do anything if the connection is revoked?
|
||||
|
||||
//@ts-ignore For some reason the client sends this as a boolean, even tho docs say its a number?
|
||||
if (typeof body.visibility === "boolean") body.visibility = body.visibility ? 1 : 0;
|
||||
//@ts-ignore For some reason the client sends this as a boolean, even tho docs say its a number?
|
||||
if (typeof body.show_activity === "boolean") body.show_activity = body.show_activity ? 1 : 0;
|
||||
if (typeof body.visibility === "boolean")
|
||||
//@ts-expect-error For some reason the client sends this as a boolean, even tho docs say its a number?
|
||||
body.visibility = body.visibility ? 1 : 0;
|
||||
if (typeof body.show_activity === "boolean")
|
||||
//@ts-expect-error For some reason the client sends this as a boolean, even tho docs say its a number?
|
||||
body.show_activity = body.show_activity ? 1 : 0;
|
||||
|
||||
connection.assign(req.body);
|
||||
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -41,13 +40,7 @@ export default class BattleNetConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
url.searchParams.append("response_type", "code");
|
||||
@ -76,10 +69,7 @@ export default class BattleNetConnection extends Connection {
|
||||
code: code,
|
||||
client_id: this.settings.clientId!,
|
||||
client_secret: this.settings.clientSecret!,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
}),
|
||||
)
|
||||
.post()
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -42,14 +41,7 @@ export default class DiscordConnection extends Connection {
|
||||
url.searchParams.append("response_type", "code");
|
||||
// controls whether, on repeated authorizations, the consent screen is shown
|
||||
url.searchParams.append("consent", "none");
|
||||
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
|
||||
return url.toString();
|
||||
}
|
||||
@ -76,10 +68,7 @@ export default class DiscordConnection extends Connection {
|
||||
client_secret: this.settings.clientSecret!,
|
||||
grant_type: "authorization_code",
|
||||
code: code,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
}),
|
||||
)
|
||||
.post()
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -47,13 +46,7 @@ export default class EpicGamesConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -46,13 +45,7 @@ export default class FacebookConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("state", state);
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
@ -65,12 +58,7 @@ export default class FacebookConnection extends Connection {
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
url.searchParams.append("client_secret", this.settings.clientSecret!);
|
||||
url.searchParams.append("code", code);
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
return url.toString();
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -36,13 +35,7 @@ export default class GitHubConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
return url.toString();
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -48,13 +47,7 @@ export default class RedditConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
@ -85,10 +78,7 @@ export default class RedditConnection extends Connection {
|
||||
new URLSearchParams({
|
||||
grant_type: "authorization_code",
|
||||
code: code,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
}),
|
||||
)
|
||||
.post()
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -57,13 +56,7 @@ export default class SpotifyConnection extends RefreshableConnection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
@ -94,10 +87,7 @@ export default class SpotifyConnection extends RefreshableConnection {
|
||||
new URLSearchParams({
|
||||
grant_type: "authorization_code",
|
||||
code: code,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
}),
|
||||
)
|
||||
.post()
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -49,13 +48,7 @@ export default class TwitchConnection extends RefreshableConnection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
@ -85,10 +78,7 @@ export default class TwitchConnection extends RefreshableConnection {
|
||||
code: code,
|
||||
client_id: this.settings.clientId!,
|
||||
client_secret: this.settings.clientSecret!,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
}),
|
||||
)
|
||||
.post()
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -49,13 +48,7 @@ export default class TwitterConnection extends RefreshableConnection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
@ -89,10 +82,7 @@ export default class TwitterConnection extends RefreshableConnection {
|
||||
grant_type: "authorization_code",
|
||||
code: code,
|
||||
client_id: this.settings.clientId!,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
code_verifier: "challenge", // TODO: properly use PKCE challenge
|
||||
}),
|
||||
)
|
||||
@ -126,10 +116,7 @@ export default class TwitterConnection extends RefreshableConnection {
|
||||
grant_type: "refresh_token",
|
||||
refresh_token,
|
||||
client_id: this.settings.clientId!,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
code_verifier: "challenge", // TODO: properly use PKCE challenge
|
||||
}),
|
||||
)
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -56,13 +55,7 @@ export default class XboxConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
@ -121,10 +114,7 @@ export default class XboxConnection extends Connection {
|
||||
grant_type: "authorization_code",
|
||||
code: code,
|
||||
client_id: this.settings.clientId!,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
scope: this.scopes.join(" "),
|
||||
}),
|
||||
)
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
Config,
|
||||
ConnectedAccount,
|
||||
ConnectedAccountCommonOAuthTokenResponse,
|
||||
ConnectionCallbackSchema,
|
||||
@ -56,13 +55,7 @@ export default class YoutubeConnection extends Connection {
|
||||
const url = new URL(this.authorizeUrl);
|
||||
|
||||
url.searchParams.append("client_id", this.settings.clientId!);
|
||||
// TODO: probably shouldn't rely on cdn as this could be different from what we actually want. we should have an api endpoint setting.
|
||||
url.searchParams.append(
|
||||
"redirect_uri",
|
||||
`${
|
||||
Config.get().cdn.endpointPrivate || "http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
);
|
||||
url.searchParams.append("redirect_uri", this.getRedirectUri());
|
||||
url.searchParams.append("response_type", "code");
|
||||
url.searchParams.append("scope", this.scopes.join(" "));
|
||||
url.searchParams.append("state", state);
|
||||
@ -92,10 +85,7 @@ export default class YoutubeConnection extends Connection {
|
||||
code: code,
|
||||
client_id: this.settings.clientId!,
|
||||
client_secret: this.settings.clientSecret!,
|
||||
redirect_uri: `${
|
||||
Config.get().cdn.endpointPrivate ||
|
||||
"http://localhost:3001"
|
||||
}/connections/${this.id}/callback`,
|
||||
redirect_uri: this.getRedirectUri(),
|
||||
}),
|
||||
)
|
||||
.post()
|
||||
|
@ -20,5 +20,5 @@ export class ApiConfiguration {
|
||||
defaultVersion: string = "9";
|
||||
activeVersions: string[] = ["6", "7", "8", "9"];
|
||||
useFosscordEnhancements: boolean = true;
|
||||
endpointPublic: string = "/api";
|
||||
endpointPublic: string | null = null;
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
import crypto from "crypto";
|
||||
import { ConnectedAccount } from "../entities";
|
||||
import { ConnectedAccountSchema, ConnectionCallbackSchema } from "../schemas";
|
||||
import { DiscordApiErrors } from "../util";
|
||||
import { Config, DiscordApiErrors } from "../util";
|
||||
|
||||
/**
|
||||
* A connection that can be used to connect to an external service.
|
||||
@ -19,6 +19,16 @@ export default abstract class Connection {
|
||||
*/
|
||||
abstract getAuthorizationUrl(userId: string): string;
|
||||
|
||||
/**
|
||||
* Returns the redirect_uri for a connection type
|
||||
* @returns redirect_uri for this connection
|
||||
*/
|
||||
getRedirectUri() {
|
||||
const endpointPublic =
|
||||
Config.get().api.endpointPublic ?? "http://localhost:3001";
|
||||
return `${endpointPublic}/connections/${this.id}/callback`;
|
||||
}
|
||||
|
||||
/**
|
||||
* Processes the callback
|
||||
* @param args Callback arguments
|
||||
|
Loading…
x
Reference in New Issue
Block a user