52ecd79736
* Bot linking button functional. * Implemented initial prototype of new Twitch signup page. * Removed old Twitch signup page. * Moved new Twitch page to correct URL. * Twitch account linking functional. * Fixed charity link. * Changed to point to live bot server. * Slightly improve spacing and alignment on Twitch page * Tidy up, handle some errors when talking to bot * Seriously do the thing where Twitch link is hidden by default * Fixed secondary Get Started button. Copy overlay and dock link now functional. * Add/remove bot from channel working. * Removed legacy Twitch controls from user profile. * Links provided by dock/overlay buttons are now correct. * Minor profile cleanup post merge. * Fixed unnecessary relinking Twitch account when logging in on Twitch page. * Added confirmation popup to refresh API key. Refreshing API key now requires a user to relink their Twitch account. * Removed legacy twitch-panel.tsx Co-authored-by: Marshall Polaris <marshall@pol.rs>
76 lines
2.4 KiB
TypeScript
76 lines
2.4 KiB
TypeScript
import { PrivateUser, User } from 'common/user'
|
|
import { generateNewApiKey } from '../api/api-key'
|
|
|
|
const TWITCH_BOT_PUBLIC_URL = 'https://king-prawn-app-5btyw.ondigitalocean.app' // TODO: Add this to env config appropriately
|
|
|
|
async function postToBot(url: string, body: unknown) {
|
|
const result = await fetch(url, {
|
|
method: 'POST',
|
|
headers: { 'Content-Type': 'application/json' },
|
|
body: JSON.stringify(body),
|
|
})
|
|
const json = await result.json()
|
|
if (!result.ok) {
|
|
throw new Error(json.message)
|
|
} else {
|
|
return json
|
|
}
|
|
}
|
|
|
|
export async function initLinkTwitchAccount(
|
|
manifoldUserID: string,
|
|
manifoldUserAPIKey: string
|
|
): Promise<[string, Promise<{ twitchName: string; controlToken: string }>]> {
|
|
const response = await postToBot(`${TWITCH_BOT_PUBLIC_URL}/api/linkInit`, {
|
|
manifoldID: manifoldUserID,
|
|
apiKey: manifoldUserAPIKey,
|
|
redirectURL: window.location.href,
|
|
})
|
|
const responseFetch = fetch(
|
|
`${TWITCH_BOT_PUBLIC_URL}/api/linkResult?userID=${manifoldUserID}`
|
|
)
|
|
return [response.twitchAuthURL, responseFetch.then((r) => r.json())]
|
|
}
|
|
|
|
export async function linkTwitchAccountRedirect(
|
|
user: User,
|
|
privateUser: PrivateUser
|
|
) {
|
|
const apiKey = privateUser.apiKey ?? (await generateNewApiKey(user.id))
|
|
if (!apiKey) throw new Error("Couldn't retrieve or create Manifold api key")
|
|
|
|
const [twitchAuthURL] = await initLinkTwitchAccount(user.id, apiKey)
|
|
|
|
window.location.href = twitchAuthURL
|
|
await new Promise((r) => setTimeout(r, 1e10)) // Wait "forever" for the page to change location
|
|
}
|
|
|
|
export async function updateBotEnabledForUser(
|
|
privateUser: PrivateUser,
|
|
botEnabled: boolean
|
|
) {
|
|
if (botEnabled) {
|
|
return postToBot(`${TWITCH_BOT_PUBLIC_URL}/registerchanneltwitch`, {
|
|
apiKey: privateUser.apiKey,
|
|
}).then((r) => {
|
|
if (!r.success) throw new Error(r.message)
|
|
})
|
|
} else {
|
|
return postToBot(`${TWITCH_BOT_PUBLIC_URL}/unregisterchanneltwitch`, {
|
|
apiKey: privateUser.apiKey,
|
|
}).then((r) => {
|
|
if (!r.success) throw new Error(r.message)
|
|
})
|
|
}
|
|
}
|
|
|
|
export function getOverlayURLForUser(privateUser: PrivateUser) {
|
|
const controlToken = privateUser?.twitchInfo?.controlToken
|
|
return `${TWITCH_BOT_PUBLIC_URL}/overlay?t=${controlToken}`
|
|
}
|
|
|
|
export function getDockURLForUser(privateUser: PrivateUser) {
|
|
const controlToken = privateUser?.twitchInfo?.controlToken
|
|
return `${TWITCH_BOT_PUBLIC_URL}/dock?t=${controlToken}`
|
|
}
|