* Add Image property to create and modify events * Add CDN routes to get cover image * Update banner names * Update CDN.cs * Update IGuildScheduledEvent.cs
248 lines
12 KiB
C#
248 lines
12 KiB
C#
using System;
|
|
|
|
namespace Discord
|
|
{
|
|
/// <summary>
|
|
/// Represents a class containing the strings related to various Content Delivery Networks (CDNs).
|
|
/// </summary>
|
|
public static class CDN
|
|
{
|
|
/// <summary>
|
|
/// Returns a team icon URL.
|
|
/// </summary>
|
|
/// <param name="teamId">The team identifier.</param>
|
|
/// <param name="iconId">The icon identifier.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the team's icon.
|
|
/// </returns>
|
|
public static string GetTeamIconUrl(ulong teamId, string iconId)
|
|
=> iconId != null ? $"{DiscordConfig.CDNUrl}team-icons/{teamId}/{iconId}.jpg" : null;
|
|
|
|
/// <summary>
|
|
/// Returns an application icon URL.
|
|
/// </summary>
|
|
/// <param name="appId">The application identifier.</param>
|
|
/// <param name="iconId">The icon identifier.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the application's icon.
|
|
/// </returns>
|
|
public static string GetApplicationIconUrl(ulong appId, string iconId)
|
|
=> iconId != null ? $"{DiscordConfig.CDNUrl}app-icons/{appId}/{iconId}.jpg" : null;
|
|
|
|
/// <summary>
|
|
/// Returns a user avatar URL.
|
|
/// </summary>
|
|
/// <param name="userId">The user snowflake identifier.</param>
|
|
/// <param name="avatarId">The avatar identifier.</param>
|
|
/// <param name="size">The size of the image to return in horizontal pixels. This can be any power of two between 16 and 2048.</param>
|
|
/// <param name="format">The format to return.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the user's avatar in the specified size.
|
|
/// </returns>
|
|
public static string GetUserAvatarUrl(ulong userId, string avatarId, ushort size, ImageFormat format)
|
|
{
|
|
if (avatarId == null)
|
|
return null;
|
|
string extension = FormatToExtension(format, avatarId);
|
|
return $"{DiscordConfig.CDNUrl}avatars/{userId}/{avatarId}.{extension}?size={size}";
|
|
}
|
|
|
|
public static string GetGuildUserAvatarUrl(ulong userId, ulong guildId, string avatarId, ushort size, ImageFormat format)
|
|
{
|
|
if (avatarId == null)
|
|
return null;
|
|
string extension = FormatToExtension(format, avatarId);
|
|
return $"{DiscordConfig.CDNUrl}guilds/{guildId}/users/{userId}/avatars/{avatarId}.{extension}?size={size}";
|
|
}
|
|
|
|
/// <summary>
|
|
/// Returns a user banner URL.
|
|
/// </summary>
|
|
/// <param name="userId">The user snowflake identifier.</param>
|
|
/// <param name="bannerId">The banner identifier.</param>
|
|
/// <param name="size">The size of the image to return in horizontal pixels. This can be any power of two between 16 and 2048.</param>
|
|
/// <param name="format">The format to return.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the user's banner in the specified size.
|
|
/// </returns>
|
|
public static string GetUserBannerUrl(ulong userId, string bannerId, ushort size, ImageFormat format)
|
|
{
|
|
if (bannerId == null)
|
|
return null;
|
|
string extension = FormatToExtension(format, bannerId);
|
|
return $"{DiscordConfig.CDNUrl}banners/{userId}/{bannerId}.{extension}?size={size}";
|
|
}
|
|
/// <summary>
|
|
/// Returns the default user avatar URL.
|
|
/// </summary>
|
|
/// <param name="discriminator">The discriminator value of a user.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the user's default avatar when one isn't set.
|
|
/// </returns>
|
|
public static string GetDefaultUserAvatarUrl(ushort discriminator)
|
|
{
|
|
return $"{DiscordConfig.CDNUrl}embed/avatars/{discriminator % 5}.png";
|
|
}
|
|
/// <summary>
|
|
/// Returns an icon URL.
|
|
/// </summary>
|
|
/// <param name="guildId">The guild snowflake identifier.</param>
|
|
/// <param name="iconId">The icon identifier.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the guild's icon.
|
|
/// </returns>
|
|
public static string GetGuildIconUrl(ulong guildId, string iconId)
|
|
=> iconId != null ? $"{DiscordConfig.CDNUrl}icons/{guildId}/{iconId}.jpg" : null;
|
|
/// <summary>
|
|
/// Returns a guild role's icon URL.
|
|
/// </summary>
|
|
/// <param name="roleId">The role identifier.</param>
|
|
/// <param name="roleHash">The icon hash.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the guild role's icon.
|
|
/// </returns>
|
|
public static string GetGuildRoleIconUrl(ulong roleId, string roleHash)
|
|
=> roleHash != null ? $"{DiscordConfig.CDNUrl}role-icons/{roleId}/{roleHash}.png" : null;
|
|
/// <summary>
|
|
/// Returns a guild splash URL.
|
|
/// </summary>
|
|
/// <param name="guildId">The guild snowflake identifier.</param>
|
|
/// <param name="splashId">The splash icon identifier.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the guild's splash.
|
|
/// </returns>
|
|
public static string GetGuildSplashUrl(ulong guildId, string splashId)
|
|
=> splashId != null ? $"{DiscordConfig.CDNUrl}splashes/{guildId}/{splashId}.jpg" : null;
|
|
/// <summary>
|
|
/// Returns a guild discovery splash URL.
|
|
/// </summary>
|
|
/// <param name="guildId">The guild snowflake identifier.</param>
|
|
/// <param name="discoverySplashId">The discovery splash icon identifier.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the guild's discovery splash.
|
|
/// </returns>
|
|
public static string GetGuildDiscoverySplashUrl(ulong guildId, string discoverySplashId)
|
|
=> discoverySplashId != null ? $"{DiscordConfig.CDNUrl}discovery-splashes/{guildId}/{discoverySplashId}.jpg" : null;
|
|
/// <summary>
|
|
/// Returns a channel icon URL.
|
|
/// </summary>
|
|
/// <param name="channelId">The channel snowflake identifier.</param>
|
|
/// <param name="iconId">The icon identifier.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the channel's icon.
|
|
/// </returns>
|
|
public static string GetChannelIconUrl(ulong channelId, string iconId)
|
|
=> iconId != null ? $"{DiscordConfig.CDNUrl}channel-icons/{channelId}/{iconId}.jpg" : null;
|
|
|
|
/// <summary>
|
|
/// Returns a guild banner URL.
|
|
/// </summary>
|
|
/// <param name="guildId">The guild snowflake identifier.</param>
|
|
/// <param name="bannerId">The banner image identifier.</param>
|
|
/// <param name="format">The format to return.</param>
|
|
/// <param name="size">The size of the image to return in horizontal pixels. This can be any power of two between 16 and 2048 inclusive.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the guild's banner image.
|
|
/// </returns>
|
|
public static string GetGuildBannerUrl(ulong guildId, string bannerId, ImageFormat format, ushort? size = null)
|
|
{
|
|
if (string.IsNullOrEmpty(bannerId))
|
|
return null;
|
|
string extension = FormatToExtension(format, bannerId);
|
|
return $"{DiscordConfig.CDNUrl}banners/{guildId}/{bannerId}.{extension}" + (size.HasValue ? $"?size={size}" : string.Empty);
|
|
}
|
|
/// <summary>
|
|
/// Returns an emoji URL.
|
|
/// </summary>
|
|
/// <param name="emojiId">The emoji snowflake identifier.</param>
|
|
/// <param name="animated">Whether this emoji is animated.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the custom emote.
|
|
/// </returns>
|
|
public static string GetEmojiUrl(ulong emojiId, bool animated)
|
|
=> $"{DiscordConfig.CDNUrl}emojis/{emojiId}.{(animated ? "gif" : "png")}";
|
|
|
|
/// <summary>
|
|
/// Returns a Rich Presence asset URL.
|
|
/// </summary>
|
|
/// <param name="appId">The application identifier.</param>
|
|
/// <param name="assetId">The asset identifier.</param>
|
|
/// <param name="size">The size of the image to return in. This can be any power of two between 16 and 2048.</param>
|
|
/// <param name="format">The format to return.</param>
|
|
/// <returns>
|
|
/// A URL pointing to the asset image in the specified size.
|
|
/// </returns>
|
|
public static string GetRichAssetUrl(ulong appId, string assetId, ushort size, ImageFormat format)
|
|
{
|
|
string extension = FormatToExtension(format, "");
|
|
return $"{DiscordConfig.CDNUrl}app-assets/{appId}/{assetId}.{extension}?size={size}";
|
|
}
|
|
|
|
/// <summary>
|
|
/// Returns a Spotify album URL.
|
|
/// </summary>
|
|
/// <param name="albumArtId">The identifier for the album art (e.g. 6be8f4c8614ecf4f1dd3ebba8d8692d8ce4951ac).</param>
|
|
/// <returns>
|
|
/// A URL pointing to the Spotify album art.
|
|
/// </returns>
|
|
public static string GetSpotifyAlbumArtUrl(string albumArtId)
|
|
=> $"https://i.scdn.co/image/{albumArtId}";
|
|
/// <summary>
|
|
/// Returns a Spotify direct URL for a track.
|
|
/// </summary>
|
|
/// <param name="trackId">The identifier for the track (e.g. 4uLU6hMCjMI75M1A2tKUQC).</param>
|
|
/// <returns>
|
|
/// A URL pointing to the Spotify track.
|
|
/// </returns>
|
|
public static string GetSpotifyDirectUrl(string trackId)
|
|
=> $"https://open.spotify.com/track/{trackId}";
|
|
|
|
/// <summary>
|
|
/// Gets a stickers url based off the id and format.
|
|
/// </summary>
|
|
/// <param name="stickerId">The id of the sticker.</param>
|
|
/// <param name="format">The format of the sticker.</param>
|
|
/// <returns>
|
|
/// A URL to the sticker.
|
|
/// </returns>
|
|
public static string GetStickerUrl(ulong stickerId, StickerFormatType format = StickerFormatType.Png)
|
|
=> $"{DiscordConfig.CDNUrl}stickers/{stickerId}.{FormatToExtension(format)}";
|
|
|
|
/// <summary>
|
|
/// Returns an events cover image url.
|
|
/// </summary>
|
|
/// <param name="guildId">The guild id that the event is in.</param>
|
|
/// <param name="eventId">The id of the event.</param>
|
|
/// <param name="assetId">The id of the cover image asset.</param>
|
|
/// <param name="format">The format of the image.</param>
|
|
/// <param name="size">The size of the image.</param>
|
|
/// <returns></returns>
|
|
public static string GetEventCoverImageUrl(ulong guildId, ulong eventId, string assetId, ImageFormat format = ImageFormat.Auto, ushort size = 1024)
|
|
=> $"{DiscordConfig.CDNUrl}guild-events/{guildId}/{eventId}/{assetId}.{FormatToExtension(format, assetId)}?size={size}";
|
|
|
|
private static string FormatToExtension(StickerFormatType format)
|
|
{
|
|
return format switch
|
|
{
|
|
StickerFormatType.None or StickerFormatType.Png or StickerFormatType.Apng => "png", // In the case of the Sticker endpoint, the sticker will be available as PNG if its format_type is PNG or APNG, and as Lottie if its format_type is LOTTIE.
|
|
StickerFormatType.Lottie => "lottie",
|
|
_ => throw new ArgumentException(nameof(format)),
|
|
};
|
|
}
|
|
|
|
private static string FormatToExtension(ImageFormat format, string imageId)
|
|
{
|
|
if (format == ImageFormat.Auto)
|
|
format = imageId.StartsWith("a_") ? ImageFormat.Gif : ImageFormat.Png;
|
|
return format switch
|
|
{
|
|
ImageFormat.Gif => "gif",
|
|
ImageFormat.Jpeg => "jpeg",
|
|
ImageFormat.Png => "png",
|
|
ImageFormat.WebP => "webp",
|
|
_ => throw new ArgumentException(nameof(format)),
|
|
};
|
|
}
|
|
}
|
|
}
|