blob: 7254c40f18c6b3de9a762fe63e976ed6de3468a2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
function generateNonce() {
var arr = new Uint8Array(20);
window.crypto.getRandomValues(arr);
return Array.from(arr, b => b.toString(16).padStart(2, "0")).join("");
}
export const _startTwitchAuth = (clientID) => (redirectURL) => () => {
const nonce = generateNonce();
document.cookie = `authnonce=${nonce}; path=/; max-age=3000`;
window.location.href =
`https://id.twitch.tv/oauth2/authorize?response_type=id_token`
+ `&client_id=${clientID}`
+ `&redirect_uri=${redirectURL}`
+ `&scope=openid`
+ `&nonce=${nonce}`
+ `&claims=${JSON.stringify({id_token: {preferred_username: null}})}`
;
};
function getFragmentQuery() {
let query = new Map();
const hashQuery = document.location.hash.slice(1).split("&");
for (let equals of hashQuery) {
const pair = equals.split("=");
query.set(decodeURIComponent(pair[0]), decodeURIComponent(pair[1]));
}
return query;
}
export const _getToken = (Just) => (Nothing) => (pair) => () => {
const frag = getFragmentQuery();
const token = frag.get("id_token");
if (token) {
document.cookie = `id_token=${token}; path=/; SameSite=Strict`;
}
let id_token = null;
let authnonce = null;
for (let c of document.cookie.split("; ")) {
const [k, v] = c.split("=");
if (k === "id_token") id_token = v;
else if (k === "authnonce") authnonce = v;
}
if (id_token && authnonce) return Just(pair(id_token)(authnonce));
return Nothing;
};
|