@discordeno/utils 22.0.1-next.b7db305 → 22.0.1-next.bb6e1f2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/base64.d.ts +6 -0
- package/dist/base64.d.ts.map +1 -1
- package/dist/base64.js +90 -13
- package/dist/images.d.ts +40 -64
- package/dist/images.d.ts.map +1 -1
- package/dist/images.js +26 -4
- package/dist/oauth2.d.ts +38 -0
- package/dist/oauth2.d.ts.map +1 -1
- package/dist/oauth2.js +33 -1
- package/package.json +13 -13
package/dist/base64.d.ts
CHANGED
|
@@ -4,6 +4,12 @@
|
|
|
4
4
|
* @param data
|
|
5
5
|
*/
|
|
6
6
|
export declare function encode(data: Uint8Array | ArrayBuffer | string): string;
|
|
7
|
+
/**
|
|
8
|
+
* Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64url representation
|
|
9
|
+
* @param data The data to encode
|
|
10
|
+
* @returns The base64url encoded string
|
|
11
|
+
*/
|
|
12
|
+
export declare function encodeBase64Url(data: Uint8Array | ArrayBuffer | string): string;
|
|
7
13
|
/**
|
|
8
14
|
* CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
|
|
9
15
|
* Decodes RFC4648 base64 string into an Uint8Array
|
package/dist/base64.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base64.d.ts","sourceRoot":"","sources":["../src/base64.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,
|
|
1
|
+
{"version":3,"file":"base64.d.ts","sourceRoot":"","sources":["../src/base64.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,CAGtE;AAED;;;;GAIG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,UAAU,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,CAG/E;AA6BD;;;;GAIG;AACH,wBAAgB,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,CAuB/C"}
|
package/dist/base64.js
CHANGED
|
@@ -4,27 +4,38 @@
|
|
|
4
4
|
* @param data
|
|
5
5
|
*/ export function encode(data) {
|
|
6
6
|
const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data);
|
|
7
|
+
return _encode(uint8, base64abc, false);
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64url representation
|
|
11
|
+
* @param data The data to encode
|
|
12
|
+
* @returns The base64url encoded string
|
|
13
|
+
*/ export function encodeBase64Url(data) {
|
|
14
|
+
const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data);
|
|
15
|
+
return _encode(uint8, base64urlAbc, true);
|
|
16
|
+
}
|
|
17
|
+
/** @private */ function _encode(data, alpha, skipPadding) {
|
|
7
18
|
let result = '';
|
|
8
19
|
let i;
|
|
9
|
-
const l =
|
|
20
|
+
const l = data.length;
|
|
10
21
|
for(i = 2; i < l; i += 3){
|
|
11
|
-
result +=
|
|
12
|
-
result +=
|
|
13
|
-
result +=
|
|
14
|
-
result +=
|
|
22
|
+
result += alpha[data[i - 2] >> 2];
|
|
23
|
+
result += alpha[(data[i - 2] & 0x03) << 4 | data[i - 1] >> 4];
|
|
24
|
+
result += alpha[(data[i - 1] & 0x0f) << 2 | data[i] >> 6];
|
|
25
|
+
result += alpha[data[i] & 0x3f];
|
|
15
26
|
}
|
|
16
27
|
if (i === l + 1) {
|
|
17
28
|
// 1 octet yet to write
|
|
18
|
-
result +=
|
|
19
|
-
result +=
|
|
20
|
-
result += '==';
|
|
29
|
+
result += alpha[data[i - 2] >> 2];
|
|
30
|
+
result += alpha[(data[i - 2] & 0x03) << 4];
|
|
31
|
+
if (!skipPadding) result += '==';
|
|
21
32
|
}
|
|
22
33
|
if (i === l) {
|
|
23
34
|
// 2 octets yet to write
|
|
24
|
-
result +=
|
|
25
|
-
result +=
|
|
26
|
-
result +=
|
|
27
|
-
result += '=';
|
|
35
|
+
result += alpha[data[i - 2] >> 2];
|
|
36
|
+
result += alpha[(data[i - 2] & 0x03) << 4 | data[i - 1] >> 4];
|
|
37
|
+
result += alpha[(data[i - 1] & 0x0f) << 2];
|
|
38
|
+
if (!skipPadding) result += '=';
|
|
28
39
|
}
|
|
29
40
|
return result;
|
|
30
41
|
}
|
|
@@ -132,6 +143,72 @@ const base64abc = [
|
|
|
132
143
|
'+',
|
|
133
144
|
'/'
|
|
134
145
|
];
|
|
146
|
+
const base64urlAbc = [
|
|
147
|
+
'A',
|
|
148
|
+
'B',
|
|
149
|
+
'C',
|
|
150
|
+
'D',
|
|
151
|
+
'E',
|
|
152
|
+
'F',
|
|
153
|
+
'G',
|
|
154
|
+
'H',
|
|
155
|
+
'I',
|
|
156
|
+
'J',
|
|
157
|
+
'K',
|
|
158
|
+
'L',
|
|
159
|
+
'M',
|
|
160
|
+
'N',
|
|
161
|
+
'O',
|
|
162
|
+
'P',
|
|
163
|
+
'Q',
|
|
164
|
+
'R',
|
|
165
|
+
'S',
|
|
166
|
+
'T',
|
|
167
|
+
'U',
|
|
168
|
+
'V',
|
|
169
|
+
'W',
|
|
170
|
+
'X',
|
|
171
|
+
'Y',
|
|
172
|
+
'Z',
|
|
173
|
+
'a',
|
|
174
|
+
'b',
|
|
175
|
+
'c',
|
|
176
|
+
'd',
|
|
177
|
+
'e',
|
|
178
|
+
'f',
|
|
179
|
+
'g',
|
|
180
|
+
'h',
|
|
181
|
+
'i',
|
|
182
|
+
'j',
|
|
183
|
+
'k',
|
|
184
|
+
'l',
|
|
185
|
+
'm',
|
|
186
|
+
'n',
|
|
187
|
+
'o',
|
|
188
|
+
'p',
|
|
189
|
+
'q',
|
|
190
|
+
'r',
|
|
191
|
+
's',
|
|
192
|
+
't',
|
|
193
|
+
'u',
|
|
194
|
+
'v',
|
|
195
|
+
'w',
|
|
196
|
+
'x',
|
|
197
|
+
'y',
|
|
198
|
+
'z',
|
|
199
|
+
'0',
|
|
200
|
+
'1',
|
|
201
|
+
'2',
|
|
202
|
+
'3',
|
|
203
|
+
'4',
|
|
204
|
+
'5',
|
|
205
|
+
'6',
|
|
206
|
+
'7',
|
|
207
|
+
'8',
|
|
208
|
+
'9',
|
|
209
|
+
'-',
|
|
210
|
+
'_'
|
|
211
|
+
];
|
|
135
212
|
// CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
|
|
136
213
|
const base64codes = [
|
|
137
214
|
255,
|
|
@@ -259,4 +336,4 @@ const base64codes = [
|
|
|
259
336
|
51
|
|
260
337
|
];
|
|
261
338
|
|
|
262
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/base64.ts"],"sourcesContent":["/**\n * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\n * Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64 representation\n * @param data\n */\nexport function encode(data: Uint8Array | ArrayBuffer | string): string {\n  const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data)\n  let result = ''\n  let i\n  const l = uint8.length\n  for (i = 2; i < l; i += 3) {\n    result += base64abc[uint8[i - 2] >> 2]\n    result += base64abc[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)]\n    result += base64abc[((uint8[i - 1] & 0x0f) << 2) | (uint8[i] >> 6)]\n    result += base64abc[uint8[i] & 0x3f]\n  }\n  if (i === l + 1) {\n    // 1 octet yet to write\n    result += base64abc[uint8[i - 2] >> 2]\n    result += base64abc[(uint8[i - 2] & 0x03) << 4]\n    result += '=='\n  }\n  if (i === l) {\n    // 2 octets yet to write\n    result += base64abc[uint8[i - 2] >> 2]\n    result += base64abc[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)]\n    result += base64abc[(uint8[i - 1] & 0x0f) << 2]\n    result += '='\n  }\n  return result\n}\n\n/**\n * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\n * Decodes RFC4648 base64 string into an Uint8Array\n * @param data\n */\nexport function decode(data: string): Uint8Array {\n  if (data.length % 4 !== 0) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  const index = data.indexOf('=')\n  if (index !== -1 && index < data.length - 2) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  const missingOctets = data.endsWith('==') ? 2 : data.endsWith('=') ? 1 : 0\n  const n = data.length\n  const result = new Uint8Array(3 * (n / 4))\n  let buffer\n  for (let i = 0, j = 0; i < n; i += 4, j += 3) {\n    buffer =\n      (getBase64Code(data.charCodeAt(i)) << 18) |\n      (getBase64Code(data.charCodeAt(i + 1)) << 12) |\n      (getBase64Code(data.charCodeAt(i + 2)) << 6) |\n      getBase64Code(data.charCodeAt(i + 3))\n    result[j] = buffer >> 16\n    result[j + 1] = (buffer >> 8) & 0xff\n    result[j + 2] = buffer & 0xff\n  }\n  return result.subarray(0, result.length - missingOctets)\n}\n\n/**\n * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\n * @param charCode\n */\nfunction getBase64Code(charCode: number): number {\n  if (charCode >= base64codes.length) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  const code = base64codes[charCode]\n  if (code === 255) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  return code\n}\n\n// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.\nconst base64abc = [\n  'A',\n  'B',\n  'C',\n  'D',\n  'E',\n  'F',\n  'G',\n  'H',\n  'I',\n  'J',\n  'K',\n  'L',\n  'M',\n  'N',\n  'O',\n  'P',\n  'Q',\n  'R',\n  'S',\n  'T',\n  'U',\n  'V',\n  'W',\n  'X',\n  'Y',\n  'Z',\n  'a',\n  'b',\n  'c',\n  'd',\n  'e',\n  'f',\n  'g',\n  'h',\n  'i',\n  'j',\n  'k',\n  'l',\n  'm',\n  'n',\n  'o',\n  'p',\n  'q',\n  'r',\n  's',\n  't',\n  'u',\n  'v',\n  'w',\n  'x',\n  'y',\n  'z',\n  '0',\n  '1',\n  '2',\n  '3',\n  '4',\n  '5',\n  '6',\n  '7',\n  '8',\n  '9',\n  '+',\n  '/',\n]\n\n// CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\nconst base64codes = [\n  255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,\n  255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 62, 255, 255, 255, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 255, 255, 255,\n  0, 255, 255, 255, 0, 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, 255, 255, 255, 255, 255, 255, 26,\n  27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51,\n]\n"],"names":["encode","data","uint8","TextEncoder","Uint8Array","result","i","l","length","base64abc","decode","Error","index","indexOf","missingOctets","endsWith","n","buffer","j","getBase64Code","charCodeAt","subarray","charCode","base64codes","code"],"mappings":"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"}
|
|
339
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/base64.ts"],"sourcesContent":["/**\n * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\n * Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64 representation\n * @param data\n */\nexport function encode(data: Uint8Array | ArrayBuffer | string): string {\n  const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data)\n  return _encode(uint8, base64abc, false)\n}\n\n/**\n * Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64url representation\n * @param data The data to encode\n * @returns The base64url encoded string\n */\nexport function encodeBase64Url(data: Uint8Array | ArrayBuffer | string): string {\n  const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data)\n  return _encode(uint8, base64urlAbc, true)\n}\n\n/** @private */\nfunction _encode(data: Uint8Array, alpha: string[], skipPadding: boolean): string {\n  let result = ''\n  let i\n  const l = data.length\n  for (i = 2; i < l; i += 3) {\n    result += alpha[data[i - 2] >> 2]\n    result += alpha[((data[i - 2] & 0x03) << 4) | (data[i - 1] >> 4)]\n    result += alpha[((data[i - 1] & 0x0f) << 2) | (data[i] >> 6)]\n    result += alpha[data[i] & 0x3f]\n  }\n  if (i === l + 1) {\n    // 1 octet yet to write\n    result += alpha[data[i - 2] >> 2]\n    result += alpha[(data[i - 2] & 0x03) << 4]\n    if (!skipPadding) result += '=='\n  }\n  if (i === l) {\n    // 2 octets yet to write\n    result += alpha[data[i - 2] >> 2]\n    result += alpha[((data[i - 2] & 0x03) << 4) | (data[i - 1] >> 4)]\n    result += alpha[(data[i - 1] & 0x0f) << 2]\n    if (!skipPadding) result += '='\n  }\n  return result\n}\n\n/**\n * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\n * Decodes RFC4648 base64 string into an Uint8Array\n * @param data\n */\nexport function decode(data: string): Uint8Array {\n  if (data.length % 4 !== 0) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  const index = data.indexOf('=')\n  if (index !== -1 && index < data.length - 2) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  const missingOctets = data.endsWith('==') ? 2 : data.endsWith('=') ? 1 : 0\n  const n = data.length\n  const result = new Uint8Array(3 * (n / 4))\n  let buffer\n  for (let i = 0, j = 0; i < n; i += 4, j += 3) {\n    buffer =\n      (getBase64Code(data.charCodeAt(i)) << 18) |\n      (getBase64Code(data.charCodeAt(i + 1)) << 12) |\n      (getBase64Code(data.charCodeAt(i + 2)) << 6) |\n      getBase64Code(data.charCodeAt(i + 3))\n    result[j] = buffer >> 16\n    result[j + 1] = (buffer >> 8) & 0xff\n    result[j + 2] = buffer & 0xff\n  }\n  return result.subarray(0, result.length - missingOctets)\n}\n\n/**\n * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\n * @param charCode\n */\nfunction getBase64Code(charCode: number): number {\n  if (charCode >= base64codes.length) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  const code = base64codes[charCode]\n  if (code === 255) {\n    throw new Error('Unable to parse base64 string.')\n  }\n  return code\n}\n\n// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.\nconst base64abc = [\n  'A',\n  'B',\n  'C',\n  'D',\n  'E',\n  'F',\n  'G',\n  'H',\n  'I',\n  'J',\n  'K',\n  'L',\n  'M',\n  'N',\n  'O',\n  'P',\n  'Q',\n  'R',\n  'S',\n  'T',\n  'U',\n  'V',\n  'W',\n  'X',\n  'Y',\n  'Z',\n  'a',\n  'b',\n  'c',\n  'd',\n  'e',\n  'f',\n  'g',\n  'h',\n  'i',\n  'j',\n  'k',\n  'l',\n  'm',\n  'n',\n  'o',\n  'p',\n  'q',\n  'r',\n  's',\n  't',\n  'u',\n  'v',\n  'w',\n  'x',\n  'y',\n  'z',\n  '0',\n  '1',\n  '2',\n  '3',\n  '4',\n  '5',\n  '6',\n  '7',\n  '8',\n  '9',\n  '+',\n  '/',\n]\n\nconst base64urlAbc = [\n  'A',\n  'B',\n  'C',\n  'D',\n  'E',\n  'F',\n  'G',\n  'H',\n  'I',\n  'J',\n  'K',\n  'L',\n  'M',\n  'N',\n  'O',\n  'P',\n  'Q',\n  'R',\n  'S',\n  'T',\n  'U',\n  'V',\n  'W',\n  'X',\n  'Y',\n  'Z',\n  'a',\n  'b',\n  'c',\n  'd',\n  'e',\n  'f',\n  'g',\n  'h',\n  'i',\n  'j',\n  'k',\n  'l',\n  'm',\n  'n',\n  'o',\n  'p',\n  'q',\n  'r',\n  's',\n  't',\n  'u',\n  'v',\n  'w',\n  'x',\n  'y',\n  'z',\n  '0',\n  '1',\n  '2',\n  '3',\n  '4',\n  '5',\n  '6',\n  '7',\n  '8',\n  '9',\n  '-',\n  '_',\n]\n\n// CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727\nconst base64codes = [\n  255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,\n  255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 62, 255, 255, 255, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 255, 255, 255,\n  0, 255, 255, 255, 0, 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, 255, 255, 255, 255, 255, 255, 26,\n  27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51,\n]\n"],"names":["encode","data","uint8","TextEncoder","Uint8Array","_encode","base64abc","encodeBase64Url","base64urlAbc","alpha","skipPadding","result","i","l","length","decode","Error","index","indexOf","missingOctets","endsWith","n","buffer","j","getBase64Code","charCodeAt","subarray","charCode","base64codes","code"],"mappings":"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;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD;AAED,MAAME,eAAe;IACnB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD;AAED,kFAAkF;AAClF,MAAMoB,cAAc;IAClB;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAC5I;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAAI;IAAK;IAAK;IAAK;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAK;IAAK;IAC/I;IAAG;IAAK;IAAK;IAAK;IAAG;IAAG;IAAG;IAAG;IAAG;IAAG;IAAG;IAAG;IAAG;IAAG;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAK;IAAK;IAAK;IAAK;IAAK;IAAK;IAC9I;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;IAAI;CACjG"}
|
package/dist/images.d.ts
CHANGED
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
import { type BigString, type GetGuildWidgetImageQuery, type ImageFormat, type ImageSize, StickerFormatTypes } from '@discordeno/types';
|
|
2
|
+
export interface ImageOptions {
|
|
3
|
+
size?: ImageSize;
|
|
4
|
+
format?: ImageFormat;
|
|
5
|
+
}
|
|
2
6
|
/** Help format an image url. */
|
|
3
7
|
export declare function formatImageUrl(url: string, size?: ImageSize, format?: ImageFormat): string;
|
|
4
8
|
/**
|
|
@@ -17,15 +21,29 @@ export declare function emojiUrl(emojiId: BigString, animated?: boolean, format?
|
|
|
17
21
|
* Builds a URL to a user's avatar stored in the Discord CDN.
|
|
18
22
|
*
|
|
19
23
|
* @param userId - The ID of the user to get the avatar of.
|
|
24
|
+
* @param avatar - The user's avatar hash.
|
|
25
|
+
* @param options - The parameters for the building of the URL.
|
|
26
|
+
* @returns The user avatar as a URL.
|
|
27
|
+
*/
|
|
28
|
+
export declare function avatarUrl(userId: BigString, avatar: BigString, options?: ImageOptions): string;
|
|
29
|
+
/**
|
|
30
|
+
* Builds a URL to a user's default avatar stored in the Discord CDN.
|
|
31
|
+
*
|
|
32
|
+
* @param userId - The ID of the user to get the avatar of.
|
|
20
33
|
* @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)
|
|
34
|
+
* @returns The user default avatar as an URL.
|
|
35
|
+
*/
|
|
36
|
+
export declare function defaultAvatarUrl(userId: BigString, discriminator: string): string;
|
|
37
|
+
/**
|
|
38
|
+
* Builds a URL to a user's display avatar stored in the Discord CDN.
|
|
39
|
+
*
|
|
40
|
+
* @param userId - The ID of the user to get the avatar of.
|
|
41
|
+
* @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)
|
|
42
|
+
* @param avatar - The user's avatar hash.
|
|
21
43
|
* @param options - The parameters for the building of the URL.
|
|
22
|
-
* @returns The
|
|
44
|
+
* @returns The user display avatar as an URL.
|
|
23
45
|
*/
|
|
24
|
-
export declare function
|
|
25
|
-
avatar: BigString | undefined;
|
|
26
|
-
size?: ImageSize;
|
|
27
|
-
format?: ImageFormat;
|
|
28
|
-
}): string;
|
|
46
|
+
export declare function displayAvatarUrl(userId: BigString, discriminator: string, avatar: BigString | undefined, options?: ImageOptions): string;
|
|
29
47
|
export declare function avatarDecorationUrl(avatarDecoration: BigString): string;
|
|
30
48
|
/**
|
|
31
49
|
* Builds a URL to a user's banner stored in the Discord CDN.
|
|
@@ -34,10 +52,8 @@ export declare function avatarDecorationUrl(avatarDecoration: BigString): string
|
|
|
34
52
|
* @param options - The parameters for the building of the URL.
|
|
35
53
|
* @returns The link to the resource or `undefined` if no banner has not been set.
|
|
36
54
|
*/
|
|
37
|
-
export declare function bannerUrl(userId: BigString, options?: {
|
|
55
|
+
export declare function bannerUrl(userId: BigString, options?: ImageOptions & {
|
|
38
56
|
banner?: BigString;
|
|
39
|
-
size?: ImageSize;
|
|
40
|
-
format?: ImageFormat;
|
|
41
57
|
}): string | undefined;
|
|
42
58
|
/**
|
|
43
59
|
* Builds a URL to the guild banner stored in the Discord CDN.
|
|
@@ -46,10 +62,8 @@ export declare function bannerUrl(userId: BigString, options?: {
|
|
|
46
62
|
* @param options - The parameters for the building of the URL.
|
|
47
63
|
* @returns The link to the resource or `undefined` if no banner has been set.
|
|
48
64
|
*/
|
|
49
|
-
export declare function guildBannerUrl(guildId: BigString, options: {
|
|
65
|
+
export declare function guildBannerUrl(guildId: BigString, options: ImageOptions & {
|
|
50
66
|
banner?: BigString;
|
|
51
|
-
size?: ImageSize;
|
|
52
|
-
format?: ImageFormat;
|
|
53
67
|
}): string | undefined;
|
|
54
68
|
/**
|
|
55
69
|
* Builds a URL to the guild icon stored in the Discord CDN.
|
|
@@ -59,10 +73,7 @@ export declare function guildBannerUrl(guildId: BigString, options: {
|
|
|
59
73
|
* @param options - The parameters for the building of the URL.
|
|
60
74
|
* @returns The link to the resource or `undefined` if no banner has been set.
|
|
61
75
|
*/
|
|
62
|
-
export declare function guildIconUrl(guildId: BigString, imageHash: BigString | undefined, options?:
|
|
63
|
-
size?: ImageSize;
|
|
64
|
-
format?: ImageFormat;
|
|
65
|
-
}): string | undefined;
|
|
76
|
+
export declare function guildIconUrl(guildId: BigString, imageHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
66
77
|
/**
|
|
67
78
|
* Builds the URL to a guild splash stored in the Discord CDN.
|
|
68
79
|
*
|
|
@@ -71,10 +82,7 @@ export declare function guildIconUrl(guildId: BigString, imageHash: BigString |
|
|
|
71
82
|
* @param options - The parameters for the building of the URL.
|
|
72
83
|
* @returns The link to the resource or `undefined` if the guild does not have a splash image set.
|
|
73
84
|
*/
|
|
74
|
-
export declare function guildSplashUrl(guildId: BigString, imageHash: BigString | undefined, options?:
|
|
75
|
-
size?: ImageSize;
|
|
76
|
-
format?: ImageFormat;
|
|
77
|
-
}): string | undefined;
|
|
85
|
+
export declare function guildSplashUrl(guildId: BigString, imageHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
78
86
|
/**
|
|
79
87
|
* Builds the URL to a guild discovery splash stored in the Discord CDN.
|
|
80
88
|
*
|
|
@@ -83,10 +91,7 @@ export declare function guildSplashUrl(guildId: BigString, imageHash: BigString
|
|
|
83
91
|
* @param options - The parameters for the building of the URL.
|
|
84
92
|
* @returns The link to the resource or `undefined` if the guild does not have a splash image set.
|
|
85
93
|
*/
|
|
86
|
-
export declare function guildDiscoverySplashUrl(guildId: BigString, imageHash: BigString | undefined, options?:
|
|
87
|
-
size?: ImageSize;
|
|
88
|
-
format?: ImageFormat;
|
|
89
|
-
}): string | undefined;
|
|
94
|
+
export declare function guildDiscoverySplashUrl(guildId: BigString, imageHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
90
95
|
/**
|
|
91
96
|
* Builds the URL to a guild scheduled event cover stored in the Discord CDN.
|
|
92
97
|
*
|
|
@@ -94,10 +99,8 @@ export declare function guildDiscoverySplashUrl(guildId: BigString, imageHash: B
|
|
|
94
99
|
* @param options - The parameters for the building of the URL.
|
|
95
100
|
* @returns The link to the resource or `undefined`.
|
|
96
101
|
*/
|
|
97
|
-
export declare function guildScheduledEventCoverUrl(eventId: BigString, options: {
|
|
102
|
+
export declare function guildScheduledEventCoverUrl(eventId: BigString, options: ImageOptions & {
|
|
98
103
|
cover?: BigString;
|
|
99
|
-
size?: ImageSize;
|
|
100
|
-
format?: ImageFormat;
|
|
101
104
|
}): string | undefined;
|
|
102
105
|
/**
|
|
103
106
|
* Builds a URL to the guild widget image stored in the Discord CDN.
|
|
@@ -115,10 +118,8 @@ export declare function getWidgetImageUrl(guildId: BigString, options?: GetGuild
|
|
|
115
118
|
* @param options - The parameters for the building of the URL.
|
|
116
119
|
* @returns The link to the resource or `undefined` if no banner has been set.
|
|
117
120
|
*/
|
|
118
|
-
export declare function memberAvatarUrl(guildId: BigString, userId: BigString, options?: {
|
|
121
|
+
export declare function memberAvatarUrl(guildId: BigString, userId: BigString, options?: ImageOptions & {
|
|
119
122
|
avatar?: BigString;
|
|
120
|
-
size?: ImageSize;
|
|
121
|
-
format?: ImageFormat;
|
|
122
123
|
}): string | undefined;
|
|
123
124
|
/**
|
|
124
125
|
* Builds a URL to a member's banner stored in the Discord CDN.
|
|
@@ -128,10 +129,8 @@ export declare function memberAvatarUrl(guildId: BigString, userId: BigString, o
|
|
|
128
129
|
* @param options - The parameters for the building of the URL.
|
|
129
130
|
* @returns The link to the resource or `undefined` if no banner has been set.
|
|
130
131
|
*/
|
|
131
|
-
export declare function memberBannerUrl(guildId: BigString, userId: BigString, options?: {
|
|
132
|
+
export declare function memberBannerUrl(guildId: BigString, userId: BigString, options?: ImageOptions & {
|
|
132
133
|
banner?: BigString;
|
|
133
|
-
size?: ImageSize;
|
|
134
|
-
format?: ImageFormat;
|
|
135
134
|
}): string | undefined;
|
|
136
135
|
/**
|
|
137
136
|
* Builds the URL to an application icon stored in the Discord CDN.
|
|
@@ -141,10 +140,7 @@ export declare function memberBannerUrl(guildId: BigString, userId: BigString, o
|
|
|
141
140
|
* @param options - The parameters for the building of the URL.
|
|
142
141
|
* @returns The link to the resource or `undefined`
|
|
143
142
|
*/
|
|
144
|
-
export declare function applicationIconUrl(applicationId: BigString, iconHash: BigString | undefined, options?:
|
|
145
|
-
size?: ImageSize;
|
|
146
|
-
format?: ImageFormat;
|
|
147
|
-
}): string | undefined;
|
|
143
|
+
export declare function applicationIconUrl(applicationId: BigString, iconHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
148
144
|
/**
|
|
149
145
|
* Builds the URL to an application cover stored in the Discord CDN.
|
|
150
146
|
*
|
|
@@ -153,10 +149,7 @@ export declare function applicationIconUrl(applicationId: BigString, iconHash: B
|
|
|
153
149
|
* @param options - The parameters for the building of the URL.
|
|
154
150
|
* @returns The link to the resource or `undefined`.
|
|
155
151
|
*/
|
|
156
|
-
export declare function applicationCoverUrl(applicationId: BigString, coverHash: BigString | undefined, options?:
|
|
157
|
-
size?: ImageSize;
|
|
158
|
-
format?: ImageFormat;
|
|
159
|
-
}): string | undefined;
|
|
152
|
+
export declare function applicationCoverUrl(applicationId: BigString, coverHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
160
153
|
/**
|
|
161
154
|
* Builds the URL to an application asset stored in the Discord CDN.
|
|
162
155
|
*
|
|
@@ -165,10 +158,7 @@ export declare function applicationCoverUrl(applicationId: BigString, coverHash:
|
|
|
165
158
|
* @param options - The parameters for the building of the URL.
|
|
166
159
|
* @returns The link to the resource or `undefined`.
|
|
167
160
|
*/
|
|
168
|
-
export declare function applicationAssetUrl(applicationId: BigString, assetId: BigString | undefined, options?:
|
|
169
|
-
size?: ImageSize;
|
|
170
|
-
format?: ImageFormat;
|
|
171
|
-
}): string | undefined;
|
|
161
|
+
export declare function applicationAssetUrl(applicationId: BigString, assetId: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
172
162
|
/**
|
|
173
163
|
* Builds the URL to a sticker pack banner stored in the Discord CDN.
|
|
174
164
|
*
|
|
@@ -176,10 +166,7 @@ export declare function applicationAssetUrl(applicationId: BigString, assetId: B
|
|
|
176
166
|
* @param options - The parameters for the building of the URL.
|
|
177
167
|
* @returns The link to the resource or `undefined`.
|
|
178
168
|
*/
|
|
179
|
-
export declare function stickerPackBannerUrl(bannerAssetId: BigString | undefined, options?:
|
|
180
|
-
size?: ImageSize;
|
|
181
|
-
format?: ImageFormat;
|
|
182
|
-
}): string | undefined;
|
|
169
|
+
export declare function stickerPackBannerUrl(bannerAssetId: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
183
170
|
/**
|
|
184
171
|
* Builds the URL to a sticker stored in the Discord CDN.
|
|
185
172
|
*
|
|
@@ -187,9 +174,7 @@ export declare function stickerPackBannerUrl(bannerAssetId: BigString | undefine
|
|
|
187
174
|
* @param options - The parameters for the building of the URL.
|
|
188
175
|
* @returns The link to the resource or `undefined`.
|
|
189
176
|
*/
|
|
190
|
-
export declare function stickerUrl(stickerId: BigString | number, options?: {
|
|
191
|
-
size?: ImageSize;
|
|
192
|
-
format?: ImageFormat;
|
|
177
|
+
export declare function stickerUrl(stickerId: BigString | number, options?: ImageOptions & {
|
|
193
178
|
type?: StickerFormatTypes;
|
|
194
179
|
}): string | undefined;
|
|
195
180
|
/**
|
|
@@ -200,10 +185,7 @@ export declare function stickerUrl(stickerId: BigString | number, options?: {
|
|
|
200
185
|
* @param options - The parameters for the building of the URL.
|
|
201
186
|
* @returns The link to the resource or `undefined`.
|
|
202
187
|
*/
|
|
203
|
-
export declare function teamIconUrl(teamId: BigString, iconHash: BigString | undefined, options?:
|
|
204
|
-
size?: ImageSize;
|
|
205
|
-
format?: ImageFormat;
|
|
206
|
-
}): string | undefined;
|
|
188
|
+
export declare function teamIconUrl(teamId: BigString, iconHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
207
189
|
/**
|
|
208
190
|
* Builds the URL to a role icon stored in the Discord CDN.
|
|
209
191
|
*
|
|
@@ -212,10 +194,7 @@ export declare function teamIconUrl(teamId: BigString, iconHash: BigString | und
|
|
|
212
194
|
* @param options - The parameters for the building of the URL.
|
|
213
195
|
* @returns The link to the resource or `undefined`.
|
|
214
196
|
*/
|
|
215
|
-
export declare function roleIconUrl(roleId: BigString, iconHash: BigString | undefined, options?:
|
|
216
|
-
size?: ImageSize;
|
|
217
|
-
format?: ImageFormat;
|
|
218
|
-
}): string | undefined;
|
|
197
|
+
export declare function roleIconUrl(roleId: BigString, iconHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
219
198
|
/**
|
|
220
199
|
* Builds the URL to a guild tag badge stored in the Discord CDN.
|
|
221
200
|
*
|
|
@@ -224,8 +203,5 @@ export declare function roleIconUrl(roleId: BigString, iconHash: BigString | und
|
|
|
224
203
|
* @param options - The parameters for the building of the URL.
|
|
225
204
|
* @returns The link to the resource or `undefined` if no badge has been set.
|
|
226
205
|
*/
|
|
227
|
-
export declare function guildTagBadgeUrl(guildId: BigString, badgeHash: BigString | undefined, options?:
|
|
228
|
-
size?: ImageSize;
|
|
229
|
-
format?: ImageFormat;
|
|
230
|
-
}): string | undefined;
|
|
206
|
+
export declare function guildTagBadgeUrl(guildId: BigString, badgeHash: BigString | undefined, options?: ImageOptions): string | undefined;
|
|
231
207
|
//# sourceMappingURL=images.d.ts.map
|
package/dist/images.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"images.d.ts","sourceRoot":"","sources":["../src/images.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,wBAAwB,EAAE,KAAK,WAAW,EAAE,KAAK,SAAS,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAGvI,gCAAgC;AAChC,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,GAAE,SAAe,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,MAAM,CAE/F;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,QAAQ,CAAC,OAAO,EAAE,SAAS,EAAE,QAAQ,UAAQ,EAAE,MAAM,GAAE,WAAmB,GAAG,MAAM,CAElG;AAED;;;;;;;GAOG;AACH,wBAAgB,SAAS,
|
|
1
|
+
{"version":3,"file":"images.d.ts","sourceRoot":"","sources":["../src/images.ts"],"names":[],"mappings":"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"}
|
package/dist/images.js
CHANGED
|
@@ -20,11 +20,33 @@ import { iconBigintToHash } from './hash.js';
|
|
|
20
20
|
* Builds a URL to a user's avatar stored in the Discord CDN.
|
|
21
21
|
*
|
|
22
22
|
* @param userId - The ID of the user to get the avatar of.
|
|
23
|
+
* @param avatar - The user's avatar hash.
|
|
24
|
+
* @param options - The parameters for the building of the URL.
|
|
25
|
+
* @returns The user avatar as a URL.
|
|
26
|
+
*/ export function avatarUrl(userId, avatar, options) {
|
|
27
|
+
return formatImageUrl(`https://cdn.discordapp.com/avatars/${userId}/${typeof avatar === 'string' ? avatar : iconBigintToHash(avatar)}`, options?.size ?? 128, options?.format);
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Builds a URL to a user's default avatar stored in the Discord CDN.
|
|
31
|
+
*
|
|
32
|
+
* @param userId - The ID of the user to get the avatar of.
|
|
23
33
|
* @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)
|
|
34
|
+
* @returns The user default avatar as an URL.
|
|
35
|
+
*/ export function defaultAvatarUrl(userId, discriminator) {
|
|
36
|
+
const isLegacy = discriminator === '0' || discriminator === '0000';
|
|
37
|
+
const index = isLegacy ? (BigInt(userId) >> 22n) % 6n : Number(discriminator) % 5;
|
|
38
|
+
return `https://cdn.discordapp.com/embed/avatars/${index}.png`;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Builds a URL to a user's display avatar stored in the Discord CDN.
|
|
42
|
+
*
|
|
43
|
+
* @param userId - The ID of the user to get the avatar of.
|
|
44
|
+
* @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)
|
|
45
|
+
* @param avatar - The user's avatar hash.
|
|
24
46
|
* @param options - The parameters for the building of the URL.
|
|
25
|
-
* @returns The
|
|
26
|
-
*/ export function
|
|
27
|
-
return
|
|
47
|
+
* @returns The user display avatar as an URL.
|
|
48
|
+
*/ export function displayAvatarUrl(userId, discriminator, avatar, options) {
|
|
49
|
+
return avatar ? avatarUrl(userId, avatar, options) : defaultAvatarUrl(userId, discriminator);
|
|
28
50
|
}
|
|
29
51
|
export function avatarDecorationUrl(avatarDecoration) {
|
|
30
52
|
return `https://cdn.discordapp.com/avatar-decoration-presets/${typeof avatarDecoration === 'string' ? avatarDecoration : iconBigintToHash(avatarDecoration)}.png`;
|
|
@@ -201,4 +223,4 @@ export function avatarDecorationUrl(avatarDecoration) {
|
|
|
201
223
|
return formatImageUrl(`https://cdn.discordapp.com/guild-tag-badges/${guildId}/${badgeHash}`, options?.size ?? 128, options?.format);
|
|
202
224
|
}
|
|
203
225
|
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/images.ts"],"sourcesContent":["import { type BigString, type GetGuildWidgetImageQuery, type ImageFormat, type ImageSize, StickerFormatTypes } from '@discordeno/types'\nimport { iconBigintToHash } from './hash.js'\n\n/** Help format an image url. */\nexport function formatImageUrl(url: string, size: ImageSize = 128, format?: ImageFormat): string {\n  return `${url}.${format ?? (url.includes('/a_') ? 'gif' : 'webp')}?size=${size}`\n}\n\n/**\n * Get the url for an emoji.\n *\n * @param emojiId The id of the emoji\n * @param animated Whether or not the emoji is animated\n * @param format The format of the image, defaults to png\n * @returns string\n *\n * @remarks\n * The animated parameter is used to specify the animated query parameter valid for webp images or to force the gif if the format is not set to webp.\n */\nexport function emojiUrl(emojiId: BigString, animated = false, format: ImageFormat = 'png'): string {\n  return `https://cdn.discordapp.com/emojis/${emojiId}.${animated ? (format === 'webp' ? 'webp' : 'gif') : format}${animated && format === 'webp' ? '?animated=true' : ''}`\n}\n\n/**\n * Builds a URL to a user's avatar stored in the Discord CDN.\n *\n * @param userId - The ID of the user to get the avatar of.\n * @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource.\n */\nexport function avatarUrl(\n  userId: BigString,\n  discriminator: string,\n  options?: {\n    avatar: BigString | undefined\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string {\n  return options?.avatar\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/avatars/${userId}/${typeof options.avatar === 'string' ? options.avatar : iconBigintToHash(options.avatar)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : `https://cdn.discordapp.com/embed/avatars/${discriminator === '0' ? (BigInt(userId) >> BigInt(22)) % BigInt(6) : Number(discriminator) % 5}.png`\n}\n\nexport function avatarDecorationUrl(avatarDecoration: BigString): string {\n  return `https://cdn.discordapp.com/avatar-decoration-presets/${\n    typeof avatarDecoration === 'string' ? avatarDecoration : iconBigintToHash(avatarDecoration)\n  }.png`\n}\n\n/**\n * Builds a URL to a user's banner stored in the Discord CDN.\n *\n * @param userId - The ID of the user to get the banner of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has not been set.\n */\nexport function bannerUrl(\n  userId: BigString,\n  options?: {\n    banner?: BigString\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return options?.banner\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/banners/${userId}/${typeof options.banner === 'string' ? options.banner : iconBigintToHash(options.banner)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to the guild banner stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the link to the banner for.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function guildBannerUrl(\n  guildId: BigString,\n  options: {\n    banner?: BigString\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return options.banner\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/banners/${guildId}/${typeof options.banner === 'string' ? options.banner : iconBigintToHash(options.banner)}`,\n        options.size ?? 128,\n        options.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to the guild icon stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the link to the banner for.\n * @param imageHash - The hash identifying the event cover image.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function guildIconUrl(\n  guildId: BigString,\n  imageHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return imageHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/icons/${guildId}/${typeof imageHash === 'string' ? imageHash : iconBigintToHash(imageHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild splash stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the splash of.\n * @param imageHash - The hash identifying the splash image.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if the guild does not have a splash image set.\n */\nexport function guildSplashUrl(\n  guildId: BigString,\n  imageHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return imageHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/splashes/${guildId}/${typeof imageHash === 'string' ? imageHash : iconBigintToHash(imageHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild discovery splash stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the splash of.\n * @param imageHash - The hash identifying the discovery splash image.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if the guild does not have a splash image set.\n */\nexport function guildDiscoverySplashUrl(\n  guildId: BigString,\n  imageHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return imageHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/discovery-splashes/${guildId}/${typeof imageHash === 'string' ? imageHash : iconBigintToHash(imageHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild scheduled event cover stored in the Discord CDN.\n *\n * @param eventId - The ID of the scheduled event to get the cover of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function guildScheduledEventCoverUrl(\n  eventId: BigString,\n  options: {\n    cover?: BigString\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return options.cover\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/guild-events/${eventId}/${typeof options.cover === 'string' ? options.cover : iconBigintToHash(options.cover)}`,\n        options.size ?? 128,\n        options.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to the guild widget image stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the link to the widget image for.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource.\n */\nexport function getWidgetImageUrl(guildId: BigString, options?: GetGuildWidgetImageQuery): string {\n  let url = `https://discordapp.com/api/guilds/${guildId}/widget.png`\n\n  if (options?.style) {\n    url += `?style=${options.style}`\n  }\n\n  return url\n}\n\n/**\n * Builds a URL to a member's avatar stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild where the member is\n * @param userId - The ID of the user to get the avatar of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function memberAvatarUrl(\n  guildId: BigString,\n  userId: BigString,\n  options?: {\n    avatar?: BigString\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return options?.avatar\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/guilds/${guildId}/users/${userId}/avatars/${\n          typeof options.avatar === 'string' ? options.avatar : iconBigintToHash(options.avatar)\n        }`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to a member's banner stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild where the member is\n * @param userId - The ID of the user to get the banner of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function memberBannerUrl(\n  guildId: BigString,\n  userId: BigString,\n  options?: {\n    banner?: BigString\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return options?.banner\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/guilds/${guildId}/users/${userId}/banners/${\n          typeof options.banner === 'string' ? options.banner : iconBigintToHash(options.banner)\n        }`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to an application icon stored in the Discord CDN.\n *\n * @param applicationId - The ID of the application to get the icon of.\n * @param iconHash - The hash identifying the application icon.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`\n */\nexport function applicationIconUrl(\n  applicationId: BigString,\n  iconHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return iconHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-icons/${applicationId}/${typeof iconHash === 'string' ? iconHash : iconBigintToHash(iconHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to an application cover stored in the Discord CDN.\n *\n * @param applicationId - The ID of the application to get the cover of.\n * @param coverHash - The hash identifying the application cover.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function applicationCoverUrl(\n  applicationId: BigString,\n  coverHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return coverHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-icons/${applicationId}/${typeof coverHash === 'string' ? coverHash : iconBigintToHash(coverHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to an application asset stored in the Discord CDN.\n *\n * @param applicationId - The ID of the application to get the asset of.\n * @param assetId - The id identifying the application asset.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function applicationAssetUrl(\n  applicationId: BigString,\n  assetId: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return assetId\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-icons/${applicationId}/${typeof assetId === 'string' ? assetId : iconBigintToHash(assetId)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a sticker pack banner stored in the Discord CDN.\n *\n * @param bannerAssetId - The ID of the banner asset for the sticker pack.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function stickerPackBannerUrl(\n  bannerAssetId: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return bannerAssetId\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-assets/710982414301790216/store/${\n          typeof bannerAssetId === 'string' ? bannerAssetId : iconBigintToHash(bannerAssetId)\n        }`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a sticker stored in the Discord CDN.\n *\n * @param stickerId - The ID of the sticker to get the icon of\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function stickerUrl(\n  stickerId: BigString | number,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n    type?: StickerFormatTypes\n  },\n): string | undefined {\n  if (!stickerId) return\n\n  const url =\n    options?.type === StickerFormatTypes.Gif\n      ? `https://media.discordapp.net/stickers/${stickerId}`\n      : `https://cdn.discordapp.com/stickers/${stickerId}`\n\n  return formatImageUrl(url, options?.size ?? 128, options?.format)\n}\n\n/**\n * Builds the URL to a team icon stored in the Discord CDN.\n *\n * @param teamId - The ID of the team to get the icon of\n * @param iconHash - The hash of the team icon.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function teamIconUrl(\n  teamId: BigString,\n  iconHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return iconHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/team-icons/${teamId}/store/${typeof iconHash === 'string' ? iconHash : iconBigintToHash(iconHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a role icon stored in the Discord CDN.\n *\n * @param roleId - The ID of the role to get the icon of\n * @param iconHash - The hash of the role icon.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function roleIconUrl(\n  roleId: BigString,\n  iconHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  return iconHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/role-icons/${roleId}/${typeof iconHash === 'string' ? iconHash : iconBigintToHash(iconHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild tag badge stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the tag badge of\n * @param badgeHash - The hash identifying the guild tag badge.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no badge has been set.\n */\nexport function guildTagBadgeUrl(\n  guildId: BigString,\n  badgeHash: BigString | undefined,\n  options?: {\n    size?: ImageSize\n    format?: ImageFormat\n  },\n): string | undefined {\n  if (badgeHash === undefined) return undefined\n\n  return formatImageUrl(`https://cdn.discordapp.com/guild-tag-badges/${guildId}/${badgeHash}`, options?.size ?? 128, options?.format)\n}\n"],"names":["StickerFormatTypes","iconBigintToHash","formatImageUrl","url","size","format","includes","emojiUrl","emojiId","animated","avatarUrl","userId","discriminator","options","avatar","BigInt","Number","avatarDecorationUrl","avatarDecoration","bannerUrl","banner","undefined","guildBannerUrl","guildId","guildIconUrl","imageHash","guildSplashUrl","guildDiscoverySplashUrl","guildScheduledEventCoverUrl","eventId","cover","getWidgetImageUrl","style","memberAvatarUrl","memberBannerUrl","applicationIconUrl","applicationId","iconHash","applicationCoverUrl","coverHash","applicationAssetUrl","assetId","stickerPackBannerUrl","bannerAssetId","stickerUrl","stickerId","type","Gif","teamIconUrl","teamId","roleIconUrl","roleId","guildTagBadgeUrl","badgeHash"],"mappings":"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"}
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/images.ts"],"sourcesContent":["import { type BigString, type GetGuildWidgetImageQuery, type ImageFormat, type ImageSize, StickerFormatTypes } from '@discordeno/types'\nimport { iconBigintToHash } from './hash.js'\n\nexport interface ImageOptions {\n  size?: ImageSize\n  format?: ImageFormat\n}\n\n/** Help format an image url. */\nexport function formatImageUrl(url: string, size: ImageSize = 128, format?: ImageFormat): string {\n  return `${url}.${format ?? (url.includes('/a_') ? 'gif' : 'webp')}?size=${size}`\n}\n\n/**\n * Get the url for an emoji.\n *\n * @param emojiId The id of the emoji\n * @param animated Whether or not the emoji is animated\n * @param format The format of the image, defaults to png\n * @returns string\n *\n * @remarks\n * The animated parameter is used to specify the animated query parameter valid for webp images or to force the gif if the format is not set to webp.\n */\nexport function emojiUrl(emojiId: BigString, animated = false, format: ImageFormat = 'png'): string {\n  return `https://cdn.discordapp.com/emojis/${emojiId}.${animated ? (format === 'webp' ? 'webp' : 'gif') : format}${animated && format === 'webp' ? '?animated=true' : ''}`\n}\n\n/**\n * Builds a URL to a user's avatar stored in the Discord CDN.\n *\n * @param userId - The ID of the user to get the avatar of.\n * @param avatar - The user's avatar hash.\n * @param options - The parameters for the building of the URL.\n * @returns The user avatar as a URL.\n */\nexport function avatarUrl(userId: BigString, avatar: BigString, options?: ImageOptions): string {\n  return formatImageUrl(\n    `https://cdn.discordapp.com/avatars/${userId}/${typeof avatar === 'string' ? avatar : iconBigintToHash(avatar)}`,\n    options?.size ?? 128,\n    options?.format,\n  )\n}\n\n/**\n * Builds a URL to a user's default avatar stored in the Discord CDN.\n *\n * @param userId - The ID of the user to get the avatar of.\n * @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)\n * @returns The user default avatar as an URL.\n */\nexport function defaultAvatarUrl(userId: BigString, discriminator: string) {\n  const isLegacy = discriminator === '0' || discriminator === '0000'\n  const index = isLegacy ? (BigInt(userId) >> 22n) % 6n : Number(discriminator) % 5\n\n  return `https://cdn.discordapp.com/embed/avatars/${index}.png`\n}\n\n/**\n * Builds a URL to a user's display avatar stored in the Discord CDN.\n *\n * @param userId - The ID of the user to get the avatar of.\n * @param discriminator - The user's discriminator. (4-digit tag after the hashtag.)\n * @param avatar - The user's avatar hash.\n * @param options - The parameters for the building of the URL.\n * @returns The user display avatar as an URL.\n */\nexport function displayAvatarUrl(userId: BigString, discriminator: string, avatar: BigString | undefined, options?: ImageOptions): string {\n  return avatar ? avatarUrl(userId, avatar, options) : defaultAvatarUrl(userId, discriminator)\n}\n\nexport function avatarDecorationUrl(avatarDecoration: BigString): string {\n  return `https://cdn.discordapp.com/avatar-decoration-presets/${\n    typeof avatarDecoration === 'string' ? avatarDecoration : iconBigintToHash(avatarDecoration)\n  }.png`\n}\n\n/**\n * Builds a URL to a user's banner stored in the Discord CDN.\n *\n * @param userId - The ID of the user to get the banner of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has not been set.\n */\nexport function bannerUrl(userId: BigString, options?: ImageOptions & { banner?: BigString }): string | undefined {\n  return options?.banner\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/banners/${userId}/${typeof options.banner === 'string' ? options.banner : iconBigintToHash(options.banner)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to the guild banner stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the link to the banner for.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function guildBannerUrl(guildId: BigString, options: ImageOptions & { banner?: BigString }): string | undefined {\n  return options.banner\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/banners/${guildId}/${typeof options.banner === 'string' ? options.banner : iconBigintToHash(options.banner)}`,\n        options.size ?? 128,\n        options.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to the guild icon stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the link to the banner for.\n * @param imageHash - The hash identifying the event cover image.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function guildIconUrl(guildId: BigString, imageHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return imageHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/icons/${guildId}/${typeof imageHash === 'string' ? imageHash : iconBigintToHash(imageHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild splash stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the splash of.\n * @param imageHash - The hash identifying the splash image.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if the guild does not have a splash image set.\n */\nexport function guildSplashUrl(guildId: BigString, imageHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return imageHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/splashes/${guildId}/${typeof imageHash === 'string' ? imageHash : iconBigintToHash(imageHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild discovery splash stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the splash of.\n * @param imageHash - The hash identifying the discovery splash image.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if the guild does not have a splash image set.\n */\nexport function guildDiscoverySplashUrl(guildId: BigString, imageHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return imageHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/discovery-splashes/${guildId}/${typeof imageHash === 'string' ? imageHash : iconBigintToHash(imageHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild scheduled event cover stored in the Discord CDN.\n *\n * @param eventId - The ID of the scheduled event to get the cover of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function guildScheduledEventCoverUrl(eventId: BigString, options: ImageOptions & { cover?: BigString }): string | undefined {\n  return options.cover\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/guild-events/${eventId}/${typeof options.cover === 'string' ? options.cover : iconBigintToHash(options.cover)}`,\n        options.size ?? 128,\n        options.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to the guild widget image stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the link to the widget image for.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource.\n */\nexport function getWidgetImageUrl(guildId: BigString, options?: GetGuildWidgetImageQuery): string {\n  let url = `https://discordapp.com/api/guilds/${guildId}/widget.png`\n\n  if (options?.style) {\n    url += `?style=${options.style}`\n  }\n\n  return url\n}\n\n/**\n * Builds a URL to a member's avatar stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild where the member is\n * @param userId - The ID of the user to get the avatar of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function memberAvatarUrl(guildId: BigString, userId: BigString, options?: ImageOptions & { avatar?: BigString }): string | undefined {\n  return options?.avatar\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/guilds/${guildId}/users/${userId}/avatars/${\n          typeof options.avatar === 'string' ? options.avatar : iconBigintToHash(options.avatar)\n        }`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds a URL to a member's banner stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild where the member is\n * @param userId - The ID of the user to get the banner of.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no banner has been set.\n */\nexport function memberBannerUrl(guildId: BigString, userId: BigString, options?: ImageOptions & { banner?: BigString }): string | undefined {\n  return options?.banner\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/guilds/${guildId}/users/${userId}/banners/${\n          typeof options.banner === 'string' ? options.banner : iconBigintToHash(options.banner)\n        }`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to an application icon stored in the Discord CDN.\n *\n * @param applicationId - The ID of the application to get the icon of.\n * @param iconHash - The hash identifying the application icon.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`\n */\nexport function applicationIconUrl(applicationId: BigString, iconHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return iconHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-icons/${applicationId}/${typeof iconHash === 'string' ? iconHash : iconBigintToHash(iconHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to an application cover stored in the Discord CDN.\n *\n * @param applicationId - The ID of the application to get the cover of.\n * @param coverHash - The hash identifying the application cover.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function applicationCoverUrl(applicationId: BigString, coverHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return coverHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-icons/${applicationId}/${typeof coverHash === 'string' ? coverHash : iconBigintToHash(coverHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to an application asset stored in the Discord CDN.\n *\n * @param applicationId - The ID of the application to get the asset of.\n * @param assetId - The id identifying the application asset.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function applicationAssetUrl(applicationId: BigString, assetId: BigString | undefined, options?: ImageOptions): string | undefined {\n  return assetId\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-icons/${applicationId}/${typeof assetId === 'string' ? assetId : iconBigintToHash(assetId)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a sticker pack banner stored in the Discord CDN.\n *\n * @param bannerAssetId - The ID of the banner asset for the sticker pack.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function stickerPackBannerUrl(bannerAssetId: BigString | undefined, options?: ImageOptions): string | undefined {\n  return bannerAssetId\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/app-assets/710982414301790216/store/${\n          typeof bannerAssetId === 'string' ? bannerAssetId : iconBigintToHash(bannerAssetId)\n        }`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a sticker stored in the Discord CDN.\n *\n * @param stickerId - The ID of the sticker to get the icon of\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function stickerUrl(stickerId: BigString | number, options?: ImageOptions & { type?: StickerFormatTypes }): string | undefined {\n  if (!stickerId) return\n\n  const url =\n    options?.type === StickerFormatTypes.Gif\n      ? `https://media.discordapp.net/stickers/${stickerId}`\n      : `https://cdn.discordapp.com/stickers/${stickerId}`\n\n  return formatImageUrl(url, options?.size ?? 128, options?.format)\n}\n\n/**\n * Builds the URL to a team icon stored in the Discord CDN.\n *\n * @param teamId - The ID of the team to get the icon of\n * @param iconHash - The hash of the team icon.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function teamIconUrl(teamId: BigString, iconHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return iconHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/team-icons/${teamId}/store/${typeof iconHash === 'string' ? iconHash : iconBigintToHash(iconHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a role icon stored in the Discord CDN.\n *\n * @param roleId - The ID of the role to get the icon of\n * @param iconHash - The hash of the role icon.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined`.\n */\nexport function roleIconUrl(roleId: BigString, iconHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  return iconHash\n    ? formatImageUrl(\n        `https://cdn.discordapp.com/role-icons/${roleId}/${typeof iconHash === 'string' ? iconHash : iconBigintToHash(iconHash)}`,\n        options?.size ?? 128,\n        options?.format,\n      )\n    : undefined\n}\n\n/**\n * Builds the URL to a guild tag badge stored in the Discord CDN.\n *\n * @param guildId - The ID of the guild to get the tag badge of\n * @param badgeHash - The hash identifying the guild tag badge.\n * @param options - The parameters for the building of the URL.\n * @returns The link to the resource or `undefined` if no badge has been set.\n */\nexport function guildTagBadgeUrl(guildId: BigString, badgeHash: BigString | undefined, options?: ImageOptions): string | undefined {\n  if (badgeHash === undefined) return undefined\n\n  return formatImageUrl(`https://cdn.discordapp.com/guild-tag-badges/${guildId}/${badgeHash}`, options?.size ?? 128, options?.format)\n}\n"],"names":["StickerFormatTypes","iconBigintToHash","formatImageUrl","url","size","format","includes","emojiUrl","emojiId","animated","avatarUrl","userId","avatar","options","defaultAvatarUrl","discriminator","isLegacy","index","BigInt","Number","displayAvatarUrl","avatarDecorationUrl","avatarDecoration","bannerUrl","banner","undefined","guildBannerUrl","guildId","guildIconUrl","imageHash","guildSplashUrl","guildDiscoverySplashUrl","guildScheduledEventCoverUrl","eventId","cover","getWidgetImageUrl","style","memberAvatarUrl","memberBannerUrl","applicationIconUrl","applicationId","iconHash","applicationCoverUrl","coverHash","applicationAssetUrl","assetId","stickerPackBannerUrl","bannerAssetId","stickerUrl","stickerId","type","Gif","teamIconUrl","teamId","roleIconUrl","roleId","guildTagBadgeUrl","badgeHash"],"mappings":"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"}
|
package/dist/oauth2.d.ts
CHANGED
|
@@ -1,5 +1,28 @@
|
|
|
1
1
|
import type { BigString, DiscordApplicationIntegrationType, OAuth2Scope, PermissionStrings } from '@discordeno/types';
|
|
2
2
|
export declare function createOAuth2Link(options: CreateOAuth2LinkOptions): string;
|
|
3
|
+
/**
|
|
4
|
+
* Generates a code verifier for use in the PKCE extension to OAuth2.
|
|
5
|
+
*
|
|
6
|
+
* @param octetLength - The length of the code verifier in octets (default is 32).
|
|
7
|
+
* @return The base64url encoded code verifier
|
|
8
|
+
*
|
|
9
|
+
* @remarks
|
|
10
|
+
* The entropy of the code verifier should be between 256 and 768 bits (32 to 96 octets), as the resulting base64url encoded string has to be between 43 and 128 characters long.
|
|
11
|
+
*
|
|
12
|
+
* @see https://datatracker.ietf.org/doc/html/rfc7636#section-7.1 for the octet length
|
|
13
|
+
* @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.1 for why 32 octets is the default
|
|
14
|
+
*/
|
|
15
|
+
export declare function generateCodeVerifier(octetLength?: number): string;
|
|
16
|
+
/**
|
|
17
|
+
* Creates a code challenge from the code verifier using the specified method.
|
|
18
|
+
*
|
|
19
|
+
* @param verifier - The code verifier to use.
|
|
20
|
+
* @returns The code challenge.
|
|
21
|
+
*
|
|
22
|
+
* @remarks
|
|
23
|
+
* This performs a SHA-256 hash on the verifier and encodes it using base64url encoding. Discord only supports 'S256' as the code challenge method.
|
|
24
|
+
*/
|
|
25
|
+
export declare function createCodeChallenge(verifier: string): Promise<string>;
|
|
3
26
|
export interface CreateOAuth2LinkOptions {
|
|
4
27
|
/**
|
|
5
28
|
* The type of response
|
|
@@ -65,5 +88,20 @@ export interface CreateOAuth2LinkOptions {
|
|
|
65
88
|
* The application must be configured in the Developer Portal to support the provided `integrationType`.
|
|
66
89
|
*/
|
|
67
90
|
integrationType?: DiscordApplicationIntegrationType;
|
|
91
|
+
/**
|
|
92
|
+
* The code challenge used to verify the authorization request
|
|
93
|
+
*
|
|
94
|
+
* @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.1
|
|
95
|
+
*/
|
|
96
|
+
codeChallenge?: string;
|
|
97
|
+
/**
|
|
98
|
+
* The challenge method used to generate the code challenge
|
|
99
|
+
*
|
|
100
|
+
* @remarks
|
|
101
|
+
* While the RFC allows for the 'plain' value to be set, discord does not allow it
|
|
102
|
+
*
|
|
103
|
+
* @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.2
|
|
104
|
+
*/
|
|
105
|
+
codeChallengeMethod?: 'S256';
|
|
68
106
|
}
|
|
69
107
|
//# sourceMappingURL=oauth2.d.ts.map
|
package/dist/oauth2.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth2.d.ts","sourceRoot":"","sources":["../src/oauth2.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,iCAAiC,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"oauth2.d.ts","sourceRoot":"","sources":["../src/oauth2.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,iCAAiC,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAA;AAIrH,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,uBAAuB,GAAG,MAAM,CAmBzE;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,oBAAoB,CAAC,WAAW,GAAE,MAAW,UAI5D;AAED;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,mBAGzD;AAED,MAAM,WAAW,uBAAuB;IACtC;;;;;OAKG;IACH,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IAC/B,gCAAgC;IAChC,QAAQ,EAAE,SAAS,CAAA;IACnB,qCAAqC;IACrC,KAAK,EAAE,WAAW,EAAE,CAAA;IACpB;;;;OAIG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;;;;OAKG;IACH,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB;;;;;;OAMG;IACH,MAAM,CAAC,EAAE,SAAS,GAAG,MAAM,CAAA;IAC3B;;;;;OAKG;IACH,WAAW,CAAC,EAAE,SAAS,GAAG,iBAAiB,EAAE,CAAA;IAC7C;;;;;OAKG;IACH,OAAO,CAAC,EAAE,SAAS,CAAA;IACnB;;;;;OAKG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B;;;;;;;;;OASG;IACH,eAAe,CAAC,EAAE,iCAAiC,CAAA;IACnD;;;;OAIG;IACH,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB;;;;;;;OAOG;IACH,mBAAmB,CAAC,EAAE,MAAM,CAAA;CAC7B"}
|
package/dist/oauth2.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { encodeBase64Url } from './base64.js';
|
|
1
2
|
import { calculateBits } from './permissions.js';
|
|
2
3
|
export function createOAuth2Link(options) {
|
|
3
4
|
const joinedScopeString = options.scope.join('%20');
|
|
@@ -10,7 +11,38 @@ export function createOAuth2Link(options) {
|
|
|
10
11
|
if (options.guildId) url += `&guild_id=${options.guildId}`;
|
|
11
12
|
if (options.disableGuildSelect !== undefined) url += `&disable_guild_select=${options.disableGuildSelect}`;
|
|
12
13
|
if (options.integrationType) url += `&integration_type=${options.integrationType}`;
|
|
14
|
+
// Options defined by RFC 7636 (https://datatracker.ietf.org/doc/html/rfc7636)
|
|
15
|
+
if (options.codeChallenge) url += `&code_challenge=${options.codeChallenge}`;
|
|
16
|
+
if (options.codeChallengeMethod) url += `&code_challenge_method=${options.codeChallengeMethod}`;
|
|
13
17
|
return url;
|
|
14
18
|
}
|
|
19
|
+
/**
|
|
20
|
+
* Generates a code verifier for use in the PKCE extension to OAuth2.
|
|
21
|
+
*
|
|
22
|
+
* @param octetLength - The length of the code verifier in octets (default is 32).
|
|
23
|
+
* @return The base64url encoded code verifier
|
|
24
|
+
*
|
|
25
|
+
* @remarks
|
|
26
|
+
* The entropy of the code verifier should be between 256 and 768 bits (32 to 96 octets), as the resulting base64url encoded string has to be between 43 and 128 characters long.
|
|
27
|
+
*
|
|
28
|
+
* @see https://datatracker.ietf.org/doc/html/rfc7636#section-7.1 for the octet length
|
|
29
|
+
* @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.1 for why 32 octets is the default
|
|
30
|
+
*/ export function generateCodeVerifier(octetLength = 32) {
|
|
31
|
+
const randomBytes = new Uint8Array(octetLength);
|
|
32
|
+
crypto.getRandomValues(randomBytes);
|
|
33
|
+
return encodeBase64Url(randomBytes);
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Creates a code challenge from the code verifier using the specified method.
|
|
37
|
+
*
|
|
38
|
+
* @param verifier - The code verifier to use.
|
|
39
|
+
* @returns The code challenge.
|
|
40
|
+
*
|
|
41
|
+
* @remarks
|
|
42
|
+
* This performs a SHA-256 hash on the verifier and encodes it using base64url encoding. Discord only supports 'S256' as the code challenge method.
|
|
43
|
+
*/ export async function createCodeChallenge(verifier) {
|
|
44
|
+
const hashed = await crypto.subtle.digest('SHA-256', new TextEncoder().encode(verifier));
|
|
45
|
+
return encodeBase64Url(hashed);
|
|
46
|
+
}
|
|
15
47
|
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9vYXV0aDIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCaWdTdHJpbmcsIERpc2NvcmRBcHBsaWNhdGlvbkludGVncmF0aW9uVHlwZSwgT0F1dGgyU2NvcGUsIFBlcm1pc3Npb25TdHJpbmdzIH0gZnJvbSAnQGRpc2NvcmRlbm8vdHlwZXMnXG5pbXBvcnQgeyBjYWxjdWxhdGVCaXRzIH0gZnJvbSAnLi9wZXJtaXNzaW9ucy5qcydcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZU9BdXRoMkxpbmsob3B0aW9uczogQ3JlYXRlT0F1dGgyTGlua09wdGlvbnMpOiBzdHJpbmcge1xuICBjb25zdCBqb2luZWRTY29wZVN0cmluZyA9IG9wdGlvbnMuc2NvcGUuam9pbignJTIwJylcblxuICBsZXQgdXJsID0gYGh0dHBzOi8vZGlzY29yZC5jb20vb2F1dGgyL2F1dGhvcml6ZT9jbGllbnRfaWQ9JHtvcHRpb25zLmNsaWVudElkfSZzY29wZT0ke2pvaW5lZFNjb3BlU3RyaW5nfWBcblxuICBpZiAob3B0aW9ucy5yZXNwb25zZVR5cGUpIHVybCArPSBgJnJlc3BvbnNlX3R5cGU9JHtvcHRpb25zLnJlc3BvbnNlVHlwZX1gXG4gIGlmIChvcHRpb25zLnN0YXRlKSB1cmwgKz0gYCZzdGF0ZT0ke2VuY29kZVVSSUNvbXBvbmVudChvcHRpb25zLnN0YXRlKX1gXG4gIGlmIChvcHRpb25zLnJlZGlyZWN0VXJpKSB1cmwgKz0gYCZyZWRpcmVjdF91cmk9JHtlbmNvZGVVUklDb21wb25lbnQob3B0aW9ucy5yZWRpcmVjdFVyaSl9YFxuICBpZiAob3B0aW9ucy5wcm9tcHQpIHVybCArPSBgJnByb21wdD0ke29wdGlvbnMucHJvbXB0fWBcbiAgaWYgKG9wdGlvbnMucGVybWlzc2lvbnMpIHVybCArPSBgJnBlcm1pc3Npb25zPSR7QXJyYXkuaXNBcnJheShvcHRpb25zLnBlcm1pc3Npb25zKSA/IGNhbGN1bGF0ZUJpdHMob3B0aW9ucy5wZXJtaXNzaW9ucykgOiBvcHRpb25zLnBlcm1pc3Npb25zfWBcbiAgaWYgKG9wdGlvbnMuZ3VpbGRJZCkgdXJsICs9IGAmZ3VpbGRfaWQ9JHtvcHRpb25zLmd1aWxkSWR9YFxuICBpZiAob3B0aW9ucy5kaXNhYmxlR3VpbGRTZWxlY3QgIT09IHVuZGVmaW5lZCkgdXJsICs9IGAmZGlzYWJsZV9ndWlsZF9zZWxlY3Q9JHtvcHRpb25zLmRpc2FibGVHdWlsZFNlbGVjdH1gXG4gIGlmIChvcHRpb25zLmludGVncmF0aW9uVHlwZSkgdXJsICs9IGAmaW50ZWdyYXRpb25fdHlwZT0ke29wdGlvbnMuaW50ZWdyYXRpb25UeXBlfWBcblxuICByZXR1cm4gdXJsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3JlYXRlT0F1dGgyTGlua09wdGlvbnMge1xuICAvKipcbiAgICogVGhlIHR5cGUgb2YgcmVzcG9uc2VcbiAgICpcbiAgICogQHJlbWFya3NcbiAgICogU2hvdWxkIGJlIGRlZmluZWQgb25seSBpZiB1c2luZyBlaXRoZXIgT0F1dGgyIGF1dGhvcml6YXRpb24sIGltcGxpY2l0IG9yIG5vdCwgb3IgW2FkdmFuY2VkIGJvdCBhdXRob3JpemF0aW9uXShodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy90b3BpY3Mvb2F1dGgyI2FkdmFuY2VkLWJvdC1hdXRob3JpemF0aW9uKVxuICAgKi9cbiAgcmVzcG9uc2VUeXBlPzogJ2NvZGUnIHwgJ3Rva2VuJ1xuICAvKiogVGhlIGlkIG9mIHRoZSBhcHBsaWNhdGlvbiAqL1xuICBjbGllbnRJZDogQmlnU3RyaW5nXG4gIC8qKiBUaGUgc2NvcGVzIGZvciB0aGUgYXBwbGljYXRpb24gKi9cbiAgc2NvcGU6IE9BdXRoMlNjb3BlW11cbiAgLyoqXG4gICAqIFRoZSBvcHRpb25hbCBzdGF0ZSBmb3Igc2VjdXJpdHlcbiAgICpcbiAgICogQHNlZSBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy90b3BpY3Mvb2F1dGgyI3N0YXRlLWFuZC1zZWN1cml0eVxuICAgKi9cbiAgc3RhdGU/OiBzdHJpbmdcbiAgLyoqXG4gICAqIFRoZSByZWRpcmVjdCB1cmkgZm9yIGFmdGVyIHRoZSBhdXRoZW50aWNhdGlvblxuICAgKlxuICAgKiBAcmVtYXJrc1xuICAgKiBTaG91bGQgYmUgZGVmaW5lZCBvbmx5IGlmIHVzaW5nIGVpdGhlciBPQXV0aDIgYXV0aG9yaXphdGlvbiwgaW1wbGljaXQgb3Igbm90LCBvciBbYWR2YW5jZWQgYm90IGF1dGhvcml6YXRpb25dKGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3RvcGljcy9vYXV0aDIjYWR2YW5jZWQtYm90LWF1dGhvcml6YXRpb24pXG4gICAqL1xuICByZWRpcmVjdFVyaT86IHN0cmluZ1xuICAvKipcbiAgICogVGhlIHR5cGUgb2YgcHJvbXB0IHRvIGdpdmUgdG8gdGhlIHVzZXJcbiAgICpcbiAgICogQHJlbWFya3NcbiAgICogSWYgc2V0IHRvIGBub25lYCwgaXQgd2lsbCBza2lwIHRoZSBhdXRob3JpemF0aW9uIHNjcmVlbiBhbmQgcmVkaXJlY3QgdGhlbSBiYWNrIHRvIHlvdXIgcmVkaXJlY3QgVVJJIHdpdGhvdXQgcmVxdWVzdGluZyB0aGVpciBhdXRob3JpemF0aW9uLlxuICAgKiBGb3IgcGFzc3Rocm91Z2ggc2NvcGVzLCBsaWtlIGJvdCBhbmQgd2ViaG9vay5pbmNvbWluZywgYXV0aG9yaXphdGlvbiBpcyBhbHdheXMgcmVxdWlyZWQuXG4gICAqL1xuICBwcm9tcHQ/OiAnY29uc2VudCcgfCAnbm9uZSdcbiAgLyoqXG4gICAqIFRoZSBwZXJtaXNzaW9ucyBvZiB0aGUgaW52aXRlZCBib3RcbiAgICpcbiAgICogQHJlbWFya3NcbiAgICogU2hvdWxkIGJlIGRlZmluZWQgb25seSBpbiBhIFtib3QgYXV0aG9yaXphdGlvbiBmbG93XShodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy90b3BpY3Mvb2F1dGgyI2JvdC1hdXRob3JpemF0aW9uLWZsb3cpIG9yIHdpdGggW2FkdmFuY2VkIGJvdCBhdXRob3JpemF0aW9uXShodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy90b3BpY3Mvb2F1dGgyI2FkdmFuY2VkLWJvdC1hdXRob3JpemF0aW9uKVxuICAgKi9cbiAgcGVybWlzc2lvbnM/OiBCaWdTdHJpbmcgfCBQZXJtaXNzaW9uU3RyaW5nc1tdXG4gIC8qKlxuICAgKiBQcmUtZmlsbHMgdGhlIGRyb3Bkb3duIHBpY2tlciB3aXRoIGEgZ3VpbGQgZm9yIHRoZSB1c2VyXG4gICAqXG4gICAqIEByZW1hcmtzXG4gICAqIFNob3VsZCBiZSBkZWZpbmVkIG9ubHkgaW4gYSBbYm90IGF1dGhvcml6YXRpb24gZmxvd10oaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvdG9waWNzL29hdXRoMiNib3QtYXV0aG9yaXphdGlvbi1mbG93KSBvciB3aXRoIFthZHZhbmNlZCBib3QgYXV0aG9yaXphdGlvbl0oaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvdG9waWNzL29hdXRoMiNhZHZhbmNlZC1ib3QtYXV0aG9yaXphdGlvbikgb3Igd2l0aCB0aGUgYHdlYmhvb2suaW5jb21pbmdgIHNjb3BlXG4gICAqL1xuICBndWlsZElkPzogQmlnU3RyaW5nXG4gIC8qKlxuICAgKiBEaXNhbGxvd3MgdGhlIHVzZXIgZnJvbSBjaGFuZ2luZyB0aGUgZ3VpbGQgZHJvcGRvd24gaWYgc2V0IHRvIHRydWVcbiAgICpcbiAgICogQHJlbWFya3NcbiAgICogU2hvdWxkIGJlIGRlZmluZWQgb25seSBpbiBhIFtib3QgYXV0aG9yaXphdGlvbiBmbG93XShodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy90b3BpY3Mvb2F1dGgyI2JvdC1hdXRob3JpemF0aW9uLWZsb3cpLCB3aXRoIFthZHZhbmNlZCBib3QgYXV0aG9yaXphdGlvbl0oaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvdG9waWNzL29hdXRoMiNhZHZhbmNlZC1ib3QtYXV0aG9yaXphdGlvbikgb3Igd2l0aCB0aGUgYHdlYmhvb2suaW5jb21pbmdgIHNjb3BlXG4gICAqL1xuICBkaXNhYmxlR3VpbGRTZWxlY3Q/OiBib29sZWFuXG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgdGhlIGluc3RhbGxhdGlvbiBjb250ZXh0IGZvciB0aGUgYXV0aG9yaXphdGlvblxuICAgKlxuICAgKiBAcmVtYXJrc1xuICAgKiBTaG91bGQgYmUgZGVmaW5lZCBvbmx5IHdoZW4ge0BsaW5rIHNjb3BlfSBpbmNsdWRlcyB7QGxpbmsgT0F1dGgyU2NvcGUuQXBwbGljYXRpb25zQ29tbWFuZHN9LlxuICAgKlxuICAgKiBXaGVuIHNldCB0byBHdWlsZEluc3RhbGwgKDApIHRoZSBhcHBsaWNhdGlvbiB3aWxsIGJlIGF1dGhvcml6ZWQgZm9yIGluc3RhbGxhdGlvbiB0byBhIHNlcnZlciwgYW5kIHdoZW4gc2V0IHRvIFVzZXJJbnN0YWxsICgxKSB0aGUgYXBwbGljYXRpb24gd2lsbCBiZSBhdXRob3JpemVkIGZvciBpbnN0YWxsYXRpb24gdG8gYSB1c2VyLlxuICAgKlxuICAgKiBUaGUgYXBwbGljYXRpb24gbXVzdCBiZSBjb25maWd1cmVkIGluIHRoZSBEZXZlbG9wZXIgUG9ydGFsIHRvIHN1cHBvcnQgdGhlIHByb3ZpZGVkIGBpbnRlZ3JhdGlvblR5cGVgLlxuICAgKi9cbiAgaW50ZWdyYXRpb25UeXBlPzogRGlzY29yZEFwcGxpY2F0aW9uSW50ZWdyYXRpb25UeXBlXG59XG4iXSwibmFtZXMiOlsiY2FsY3VsYXRlQml0cyIsImNyZWF0ZU9BdXRoMkxpbmsiLCJvcHRpb25zIiwiam9pbmVkU2NvcGVTdHJpbmciLCJzY29wZSIsImpvaW4iLCJ1cmwiLCJjbGllbnRJZCIsInJlc3BvbnNlVHlwZSIsInN0YXRlIiwiZW5jb2RlVVJJQ29tcG9uZW50IiwicmVkaXJlY3RVcmkiLCJwcm9tcHQiLCJwZXJtaXNzaW9ucyIsIkFycmF5IiwiaXNBcnJheSIsImd1aWxkSWQiLCJkaXNhYmxlR3VpbGRTZWxlY3QiLCJ1bmRlZmluZWQiLCJpbnRlZ3JhdGlvblR5cGUiXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLGFBQWEsUUFBUSxtQkFBa0I7QUFFaEQsT0FBTyxTQUFTQyxpQkFBaUJDLE9BQWdDO0lBQy9ELE1BQU1DLG9CQUFvQkQsUUFBUUUsS0FBSyxDQUFDQyxJQUFJLENBQUM7SUFFN0MsSUFBSUMsTUFBTSxDQUFDLCtDQUErQyxFQUFFSixRQUFRSyxRQUFRLENBQUMsT0FBTyxFQUFFSixtQkFBbUI7SUFFekcsSUFBSUQsUUFBUU0sWUFBWSxFQUFFRixPQUFPLENBQUMsZUFBZSxFQUFFSixRQUFRTSxZQUFZLEVBQUU7SUFDekUsSUFBSU4sUUFBUU8sS0FBSyxFQUFFSCxPQUFPLENBQUMsT0FBTyxFQUFFSSxtQkFBbUJSLFFBQVFPLEtBQUssR0FBRztJQUN2RSxJQUFJUCxRQUFRUyxXQUFXLEVBQUVMLE9BQU8sQ0FBQyxjQUFjLEVBQUVJLG1CQUFtQlIsUUFBUVMsV0FBVyxHQUFHO0lBQzFGLElBQUlULFFBQVFVLE1BQU0sRUFBRU4sT0FBTyxDQUFDLFFBQVEsRUFBRUosUUFBUVUsTUFBTSxFQUFFO0lBQ3RELElBQUlWLFFBQVFXLFdBQVcsRUFBRVAsT0FBTyxDQUFDLGFBQWEsRUFBRVEsTUFBTUMsT0FBTyxDQUFDYixRQUFRVyxXQUFXLElBQUliLGNBQWNFLFFBQVFXLFdBQVcsSUFBSVgsUUFBUVcsV0FBVyxFQUFFO0lBQy9JLElBQUlYLFFBQVFjLE9BQU8sRUFBRVYsT0FBTyxDQUFDLFVBQVUsRUFBRUosUUFBUWMsT0FBTyxFQUFFO0lBQzFELElBQUlkLFFBQVFlLGtCQUFrQixLQUFLQyxXQUFXWixPQUFPLENBQUMsc0JBQXNCLEVBQUVKLFFBQVFlLGtCQUFrQixFQUFFO0lBQzFHLElBQUlmLFFBQVFpQixlQUFlLEVBQUViLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRUosUUFBUWlCLGVBQWUsRUFBRTtJQUVsRixPQUFPYjtBQUNUIn0=
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/oauth2.ts"],"sourcesContent":["import type { BigString, DiscordApplicationIntegrationType, OAuth2Scope, PermissionStrings } from '@discordeno/types'\nimport { encodeBase64Url } from './base64.js'\nimport { calculateBits } from './permissions.js'\n\nexport function createOAuth2Link(options: CreateOAuth2LinkOptions): string {\n  const joinedScopeString = options.scope.join('%20')\n\n  let url = `https://discord.com/oauth2/authorize?client_id=${options.clientId}&scope=${joinedScopeString}`\n\n  if (options.responseType) url += `&response_type=${options.responseType}`\n  if (options.state) url += `&state=${encodeURIComponent(options.state)}`\n  if (options.redirectUri) url += `&redirect_uri=${encodeURIComponent(options.redirectUri)}`\n  if (options.prompt) url += `&prompt=${options.prompt}`\n  if (options.permissions) url += `&permissions=${Array.isArray(options.permissions) ? calculateBits(options.permissions) : options.permissions}`\n  if (options.guildId) url += `&guild_id=${options.guildId}`\n  if (options.disableGuildSelect !== undefined) url += `&disable_guild_select=${options.disableGuildSelect}`\n  if (options.integrationType) url += `&integration_type=${options.integrationType}`\n\n  // Options defined by RFC 7636 (https://datatracker.ietf.org/doc/html/rfc7636)\n  if (options.codeChallenge) url += `&code_challenge=${options.codeChallenge}`\n  if (options.codeChallengeMethod) url += `&code_challenge_method=${options.codeChallengeMethod}`\n\n  return url\n}\n\n/**\n * Generates a code verifier for use in the PKCE extension to OAuth2.\n *\n * @param octetLength - The length of the code verifier in octets (default is 32).\n * @return The base64url encoded code verifier\n *\n * @remarks\n * The entropy of the code verifier should be between 256 and 768 bits (32 to 96 octets), as the resulting base64url encoded string has to be between 43 and 128 characters long.\n *\n * @see https://datatracker.ietf.org/doc/html/rfc7636#section-7.1 for the octet length\n * @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.1 for why 32 octets is the default\n */\nexport function generateCodeVerifier(octetLength: number = 32) {\n  const randomBytes = new Uint8Array(octetLength)\n  crypto.getRandomValues(randomBytes)\n  return encodeBase64Url(randomBytes)\n}\n\n/**\n * Creates a code challenge from the code verifier using the specified method.\n *\n * @param verifier - The code verifier to use.\n * @returns The code challenge.\n *\n * @remarks\n * This performs a SHA-256 hash on the verifier and encodes it using base64url encoding. Discord only supports 'S256' as the code challenge method.\n */\nexport async function createCodeChallenge(verifier: string) {\n  const hashed = await crypto.subtle.digest('SHA-256', new TextEncoder().encode(verifier))\n  return encodeBase64Url(hashed)\n}\n\nexport interface CreateOAuth2LinkOptions {\n  /**\n   * The type of response\n   *\n   * @remarks\n   * Should be defined only if using either OAuth2 authorization, implicit or not, or [advanced bot authorization](https://discord.com/developers/docs/topics/oauth2#advanced-bot-authorization)\n   */\n  responseType?: 'code' | 'token'\n  /** The id of the application */\n  clientId: BigString\n  /** The scopes for the application */\n  scope: OAuth2Scope[]\n  /**\n   * The optional state for security\n   *\n   * @see https://discord.com/developers/docs/topics/oauth2#state-and-security\n   */\n  state?: string\n  /**\n   * The redirect uri for after the authentication\n   *\n   * @remarks\n   * Should be defined only if using either OAuth2 authorization, implicit or not, or [advanced bot authorization](https://discord.com/developers/docs/topics/oauth2#advanced-bot-authorization)\n   */\n  redirectUri?: string\n  /**\n   * The type of prompt to give to the user\n   *\n   * @remarks\n   * If set to `none`, it will skip the authorization screen and redirect them back to your redirect URI without requesting their authorization.\n   * For passthrough scopes, like bot and webhook.incoming, authorization is always required.\n   */\n  prompt?: 'consent' | 'none'\n  /**\n   * The permissions of the invited bot\n   *\n   * @remarks\n   * Should be defined only in a [bot authorization flow](https://discord.com/developers/docs/topics/oauth2#bot-authorization-flow) or with [advanced bot authorization](https://discord.com/developers/docs/topics/oauth2#advanced-bot-authorization)\n   */\n  permissions?: BigString | PermissionStrings[]\n  /**\n   * Pre-fills the dropdown picker with a guild for the user\n   *\n   * @remarks\n   * Should be defined only in a [bot authorization flow](https://discord.com/developers/docs/topics/oauth2#bot-authorization-flow) or with [advanced bot authorization](https://discord.com/developers/docs/topics/oauth2#advanced-bot-authorization) or with the `webhook.incoming` scope\n   */\n  guildId?: BigString\n  /**\n   * Disallows the user from changing the guild dropdown if set to true\n   *\n   * @remarks\n   * Should be defined only in a [bot authorization flow](https://discord.com/developers/docs/topics/oauth2#bot-authorization-flow), with [advanced bot authorization](https://discord.com/developers/docs/topics/oauth2#advanced-bot-authorization) or with the `webhook.incoming` scope\n   */\n  disableGuildSelect?: boolean\n  /**\n   * Specifies the installation context for the authorization\n   *\n   * @remarks\n   * Should be defined only when {@link scope} includes {@link OAuth2Scope.ApplicationsCommands}.\n   *\n   * When set to GuildInstall (0) the application will be authorized for installation to a server, and when set to UserInstall (1) the application will be authorized for installation to a user.\n   *\n   * The application must be configured in the Developer Portal to support the provided `integrationType`.\n   */\n  integrationType?: DiscordApplicationIntegrationType\n  /**\n   * The code challenge used to verify the authorization request\n   *\n   * @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.1\n   */\n  codeChallenge?: string\n  /**\n   * The challenge method used to generate the code challenge\n   *\n   * @remarks\n   * While the RFC allows for the 'plain' value to be set, discord does not allow it\n   *\n   * @see https://datatracker.ietf.org/doc/html/rfc7636#section-4.2\n   */\n  codeChallengeMethod?: 'S256'\n}\n"],"names":["encodeBase64Url","calculateBits","createOAuth2Link","options","joinedScopeString","scope","join","url","clientId","responseType","state","encodeURIComponent","redirectUri","prompt","permissions","Array","isArray","guildId","disableGuildSelect","undefined","integrationType","codeChallenge","codeChallengeMethod","generateCodeVerifier","octetLength","randomBytes","Uint8Array","crypto","getRandomValues","createCodeChallenge","verifier","hashed","subtle","digest","TextEncoder","encode"],"mappings":"AACA,SAASA,eAAe,QAAQ,cAAa;AAC7C,SAASC,aAAa,QAAQ,mBAAkB;AAEhD,OAAO,SAASC,iBAAiBC,OAAgC;IAC/D,MAAMC,oBAAoBD,QAAQE,KAAK,CAACC,IAAI,CAAC;IAE7C,IAAIC,MAAM,CAAC,+CAA+C,EAAEJ,QAAQK,QAAQ,CAAC,OAAO,EAAEJ,mBAAmB;IAEzG,IAAID,QAAQM,YAAY,EAAEF,OAAO,CAAC,eAAe,EAAEJ,QAAQM,YAAY,EAAE;IACzE,IAAIN,QAAQO,KAAK,EAAEH,OAAO,CAAC,OAAO,EAAEI,mBAAmBR,QAAQO,KAAK,GAAG;IACvE,IAAIP,QAAQS,WAAW,EAAEL,OAAO,CAAC,cAAc,EAAEI,mBAAmBR,QAAQS,WAAW,GAAG;IAC1F,IAAIT,QAAQU,MAAM,EAAEN,OAAO,CAAC,QAAQ,EAAEJ,QAAQU,MAAM,EAAE;IACtD,IAAIV,QAAQW,WAAW,EAAEP,OAAO,CAAC,aAAa,EAAEQ,MAAMC,OAAO,CAACb,QAAQW,WAAW,IAAIb,cAAcE,QAAQW,WAAW,IAAIX,QAAQW,WAAW,EAAE;IAC/I,IAAIX,QAAQc,OAAO,EAAEV,OAAO,CAAC,UAAU,EAAEJ,QAAQc,OAAO,EAAE;IAC1D,IAAId,QAAQe,kBAAkB,KAAKC,WAAWZ,OAAO,CAAC,sBAAsB,EAAEJ,QAAQe,kBAAkB,EAAE;IAC1G,IAAIf,QAAQiB,eAAe,EAAEb,OAAO,CAAC,kBAAkB,EAAEJ,QAAQiB,eAAe,EAAE;IAElF,8EAA8E;IAC9E,IAAIjB,QAAQkB,aAAa,EAAEd,OAAO,CAAC,gBAAgB,EAAEJ,QAAQkB,aAAa,EAAE;IAC5E,IAAIlB,QAAQmB,mBAAmB,EAAEf,OAAO,CAAC,uBAAuB,EAAEJ,QAAQmB,mBAAmB,EAAE;IAE/F,OAAOf;AACT;AAEA;;;;;;;;;;;CAWC,GACD,OAAO,SAASgB,qBAAqBC,cAAsB,EAAE;IAC3D,MAAMC,cAAc,IAAIC,WAAWF;IACnCG,OAAOC,eAAe,CAACH;IACvB,OAAOzB,gBAAgByB;AACzB;AAEA;;;;;;;;CAQC,GACD,OAAO,eAAeI,oBAAoBC,QAAgB;IACxD,MAAMC,SAAS,MAAMJ,OAAOK,MAAM,CAACC,MAAM,CAAC,WAAW,IAAIC,cAAcC,MAAM,CAACL;IAC9E,OAAO9B,gBAAgB+B;AACzB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@discordeno/utils",
|
|
3
|
-
"version": "22.0.1-next.
|
|
3
|
+
"version": "22.0.1-next.bb6e1f2",
|
|
4
4
|
"exports": "./dist/index.js",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
"!dist/.tsbuildinfo"
|
|
14
14
|
],
|
|
15
15
|
"scripts": {
|
|
16
|
-
"build": "swc src --strip-leading-paths
|
|
16
|
+
"build": "swc src --strip-leading-paths src --out-dir dist",
|
|
17
17
|
"build:type": "tsc --declaration --emitDeclarationOnly --declarationDir dist",
|
|
18
18
|
"release-build": "yarn build && yarn build:type",
|
|
19
19
|
"check": "biome check --write",
|
|
@@ -26,22 +26,22 @@
|
|
|
26
26
|
"test:test-type": "tsc --project tests/tsconfig.json"
|
|
27
27
|
},
|
|
28
28
|
"dependencies": {
|
|
29
|
-
"@discordeno/types": "22.0.1-next.
|
|
29
|
+
"@discordeno/types": "22.0.1-next.bb6e1f2"
|
|
30
30
|
},
|
|
31
31
|
"devDependencies": {
|
|
32
|
-
"@biomejs/biome": "2.
|
|
33
|
-
"@swc/cli": "^0.7.
|
|
34
|
-
"@swc/core": "^1.
|
|
35
|
-
"@types/chai": "^5.2.
|
|
32
|
+
"@biomejs/biome": "2.3.10",
|
|
33
|
+
"@swc/cli": "^0.7.9",
|
|
34
|
+
"@swc/core": "^1.15.8",
|
|
35
|
+
"@types/chai": "^5.2.3",
|
|
36
36
|
"@types/mocha": "^10.0.10",
|
|
37
|
-
"@types/node": "^
|
|
38
|
-
"@types/sinon": "^
|
|
37
|
+
"@types/node": "^25.0.3",
|
|
38
|
+
"@types/sinon": "^21.0.0",
|
|
39
39
|
"c8": "^10.1.3",
|
|
40
|
-
"chai": "^
|
|
41
|
-
"mocha": "
|
|
42
|
-
"sinon": "^21.0.
|
|
40
|
+
"chai": "^6.2.2",
|
|
41
|
+
"mocha": "^11.7.5",
|
|
42
|
+
"sinon": "^21.0.1",
|
|
43
43
|
"ts-node": "^10.9.2",
|
|
44
44
|
"tsconfig": "*",
|
|
45
|
-
"typescript": "^5.9.
|
|
45
|
+
"typescript": "^5.9.3"
|
|
46
46
|
}
|
|
47
47
|
}
|