@discordeno/utils 22.0.1-next.a85207e → 22.0.1-next.abff4d2
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/images.d.ts.map +1 -1
- package/dist/images.js +4 -2
- package/dist/oauth2.d.ts +6 -6
- package/dist/oauth2.js +1 -1
- package/package.json +7 -7
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,CAAC;AAGxI,MAAM,WAAW,YAAY;IAC3B,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,MAAM,CAAC,EAAE,WAAW,CAAC;CACtB;AAED,gCAAgC;AAChC,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,GAAE,SAAe,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,MAAM,
|
|
1
|
+
{"version":3,"file":"images.d.ts","sourceRoot":"","sources":["../src/images.ts"],"names":[],"mappings":"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"}
|
package/dist/images.js
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { StickerFormatTypes } from '@discordeno/types';
|
|
2
2
|
import { iconBigintToHash } from './hash.js';
|
|
3
3
|
/** Help format an image url. */ export function formatImageUrl(url, size = 128, format) {
|
|
4
|
-
|
|
4
|
+
const animated = url.includes('/a_');
|
|
5
|
+
format ??= animated ? 'gif' : 'webp';
|
|
6
|
+
return `${url}.${format}?size=${size}${animated && format === 'webp' ? '&animated=true' : ''}`;
|
|
5
7
|
}
|
|
6
8
|
/**
|
|
7
9
|
* Get the url for an emoji.
|
|
@@ -223,4 +225,4 @@ export function avatarDecorationUrl(avatarDecoration) {
|
|
|
223
225
|
return formatImageUrl(`https://cdn.discordapp.com/guild-tag-badges/${guildId}/${badgeHash}`, options?.size ?? 128, options?.format);
|
|
224
226
|
}
|
|
225
227
|
|
|
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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"}
|
|
228
|
+
//# 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  const animated = url.includes('/a_');\n  format ??= animated ? 'gif' : 'webp';\n\n  return `${url}.${format}?size=${size}${animated && format === 'webp' ? '&animated=true' : ''}`;\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","animated","includes","emojiUrl","emojiId","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
|
@@ -28,7 +28,7 @@ export interface CreateOAuth2LinkOptions {
|
|
|
28
28
|
* The type of response
|
|
29
29
|
*
|
|
30
30
|
* @remarks
|
|
31
|
-
* Should be defined only if using either OAuth2 authorization, implicit or not, or [advanced bot authorization](https://discord.com/developers/
|
|
31
|
+
* Should be defined only if using either OAuth2 authorization, implicit or not, or [advanced bot authorization](https://docs.discord.com/developers/topics/oauth2#advanced-bot-authorization)
|
|
32
32
|
*/
|
|
33
33
|
responseType?: 'code' | 'token';
|
|
34
34
|
/** The id of the application */
|
|
@@ -38,14 +38,14 @@ export interface CreateOAuth2LinkOptions {
|
|
|
38
38
|
/**
|
|
39
39
|
* The optional state for security
|
|
40
40
|
*
|
|
41
|
-
* @see https://discord.com/developers/
|
|
41
|
+
* @see https://docs.discord.com/developers/topics/oauth2#state-and-security
|
|
42
42
|
*/
|
|
43
43
|
state?: string;
|
|
44
44
|
/**
|
|
45
45
|
* The redirect uri for after the authentication
|
|
46
46
|
*
|
|
47
47
|
* @remarks
|
|
48
|
-
* Should be defined only if using either OAuth2 authorization, implicit or not, or [advanced bot authorization](https://discord.com/developers/
|
|
48
|
+
* Should be defined only if using either OAuth2 authorization, implicit or not, or [advanced bot authorization](https://docs.discord.com/developers/topics/oauth2#advanced-bot-authorization)
|
|
49
49
|
*/
|
|
50
50
|
redirectUri?: string;
|
|
51
51
|
/**
|
|
@@ -60,21 +60,21 @@ export interface CreateOAuth2LinkOptions {
|
|
|
60
60
|
* The permissions of the invited bot
|
|
61
61
|
*
|
|
62
62
|
* @remarks
|
|
63
|
-
* Should be defined only in a [bot authorization flow](https://discord.com/developers/
|
|
63
|
+
* Should be defined only in a [bot authorization flow](https://docs.discord.com/developers/topics/oauth2#bot-authorization-flow) or with [advanced bot authorization](https://docs.discord.com/developers/topics/oauth2#advanced-bot-authorization)
|
|
64
64
|
*/
|
|
65
65
|
permissions?: BigString | PermissionStrings[];
|
|
66
66
|
/**
|
|
67
67
|
* Pre-fills the dropdown picker with a guild for the user
|
|
68
68
|
*
|
|
69
69
|
* @remarks
|
|
70
|
-
* Should be defined only in a [bot authorization flow](https://discord.com/developers/
|
|
70
|
+
* Should be defined only in a [bot authorization flow](https://docs.discord.com/developers/topics/oauth2#bot-authorization-flow) or with [advanced bot authorization](https://docs.discord.com/developers/topics/oauth2#advanced-bot-authorization) or with the `webhook.incoming` scope
|
|
71
71
|
*/
|
|
72
72
|
guildId?: BigString;
|
|
73
73
|
/**
|
|
74
74
|
* Disallows the user from changing the guild dropdown if set to true
|
|
75
75
|
*
|
|
76
76
|
* @remarks
|
|
77
|
-
* Should be defined only in a [bot authorization flow](https://discord.com/developers/
|
|
77
|
+
* Should be defined only in a [bot authorization flow](https://docs.discord.com/developers/topics/oauth2#bot-authorization-flow), with [advanced bot authorization](https://docs.discord.com/developers/topics/oauth2#advanced-bot-authorization) or with the `webhook.incoming` scope
|
|
78
78
|
*/
|
|
79
79
|
disableGuildSelect?: boolean;
|
|
80
80
|
/**
|
package/dist/oauth2.js
CHANGED
|
@@ -45,4 +45,4 @@ export function createOAuth2Link(options) {
|
|
|
45
45
|
return encodeBase64Url(hashed);
|
|
46
46
|
}
|
|
47
47
|
|
|
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,cAAc;AAC9C,SAASC,aAAa,QAAQ,mBAAmB;AAEjD,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"}
|
|
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://docs.discord.com/developers/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://docs.discord.com/developers/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://docs.discord.com/developers/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://docs.discord.com/developers/topics/oauth2#bot-authorization-flow) or with [advanced bot authorization](https://docs.discord.com/developers/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://docs.discord.com/developers/topics/oauth2#bot-authorization-flow) or with [advanced bot authorization](https://docs.discord.com/developers/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://docs.discord.com/developers/topics/oauth2#bot-authorization-flow), with [advanced bot authorization](https://docs.discord.com/developers/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,cAAc;AAC9C,SAASC,aAAa,QAAQ,mBAAmB;AAEjD,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.abff4d2",
|
|
4
4
|
"exports": "./dist/index.js",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -24,17 +24,17 @@
|
|
|
24
24
|
"test:type": "tsc --noEmit"
|
|
25
25
|
},
|
|
26
26
|
"dependencies": {
|
|
27
|
-
"@discordeno/types": "22.0.1-next.
|
|
27
|
+
"@discordeno/types": "22.0.1-next.abff4d2"
|
|
28
28
|
},
|
|
29
29
|
"devDependencies": {
|
|
30
|
-
"@biomejs/biome": "2.
|
|
31
|
-
"@swc/cli": "^0.
|
|
32
|
-
"@swc/core": "^1.15.
|
|
30
|
+
"@biomejs/biome": "2.4.4",
|
|
31
|
+
"@swc/cli": "^0.8.0",
|
|
32
|
+
"@swc/core": "^1.15.18",
|
|
33
33
|
"@types/chai": "^5.2.3",
|
|
34
34
|
"@types/mocha": "^10.0.10",
|
|
35
|
-
"@types/node": "^25.
|
|
35
|
+
"@types/node": "^25.3.3",
|
|
36
36
|
"@types/sinon": "^21.0.0",
|
|
37
|
-
"c8": "^
|
|
37
|
+
"c8": "^11.0.0",
|
|
38
38
|
"chai": "^6.2.2",
|
|
39
39
|
"mocha": "^11.7.5",
|
|
40
40
|
"sinon": "^21.0.1",
|