[Feature] Add AppliedTags to DiscordWebhookClient.SendXAsync (#2805)
This commit is contained in:
@@ -45,6 +45,9 @@ namespace Discord.API.Rest
|
|||||||
[JsonProperty("thread_name")]
|
[JsonProperty("thread_name")]
|
||||||
public Optional<string> ThreadName { get; set; }
|
public Optional<string> ThreadName { get; set; }
|
||||||
|
|
||||||
|
[JsonProperty("applied_tags")]
|
||||||
|
public Optional<ulong[]> AppliedTags { get; set; }
|
||||||
|
|
||||||
public IReadOnlyDictionary<string, object> ToDictionary()
|
public IReadOnlyDictionary<string, object> ToDictionary()
|
||||||
{
|
{
|
||||||
var d = new Dictionary<string, object>();
|
var d = new Dictionary<string, object>();
|
||||||
@@ -75,6 +78,8 @@ namespace Discord.API.Rest
|
|||||||
payload["components"] = Components.Value;
|
payload["components"] = Components.Value;
|
||||||
if (ThreadName.IsSpecified)
|
if (ThreadName.IsSpecified)
|
||||||
payload["thread_name"] = ThreadName.Value;
|
payload["thread_name"] = ThreadName.Value;
|
||||||
|
if (AppliedTags.IsSpecified)
|
||||||
|
payload["applied_tags"] = AppliedTags.Value;
|
||||||
|
|
||||||
var json = new StringBuilder();
|
var json = new StringBuilder();
|
||||||
using (var text = new StringWriter(json))
|
using (var text = new StringWriter(json))
|
||||||
|
|||||||
@@ -23,6 +23,7 @@ namespace Discord.API.Rest
|
|||||||
public Optional<ActionRowComponent[]> MessageComponents { get; set; }
|
public Optional<ActionRowComponent[]> MessageComponents { get; set; }
|
||||||
public Optional<MessageFlags> Flags { get; set; }
|
public Optional<MessageFlags> Flags { get; set; }
|
||||||
public Optional<string> ThreadName { get; set; }
|
public Optional<string> ThreadName { get; set; }
|
||||||
|
public Optional<ulong[]> AppliedTags { get; set; }
|
||||||
|
|
||||||
public UploadWebhookFileParams(params FileAttachment[] files)
|
public UploadWebhookFileParams(params FileAttachment[] files)
|
||||||
{
|
{
|
||||||
@@ -54,6 +55,8 @@ namespace Discord.API.Rest
|
|||||||
payload["flags"] = Flags.Value;
|
payload["flags"] = Flags.Value;
|
||||||
if (ThreadName.IsSpecified)
|
if (ThreadName.IsSpecified)
|
||||||
payload["thread_name"] = ThreadName.Value;
|
payload["thread_name"] = ThreadName.Value;
|
||||||
|
if (AppliedTags.IsSpecified)
|
||||||
|
payload["applied_tags"] = AppliedTags.Value;
|
||||||
|
|
||||||
List<object> attachments = new();
|
List<object> attachments = new();
|
||||||
|
|
||||||
|
|||||||
@@ -114,8 +114,9 @@ public class DiscordWebhookClient : IDisposable
|
|||||||
/// </returns>
|
/// </returns>
|
||||||
public Task<ulong> SendMessageAsync(string text = null, bool isTTS = false, IEnumerable<Embed> embeds = null,
|
public Task<ulong> SendMessageAsync(string text = null, bool isTTS = false, IEnumerable<Embed> embeds = null,
|
||||||
string username = null, string avatarUrl = null, RequestOptions options = null, AllowedMentions allowedMentions = null,
|
string username = null, string avatarUrl = null, RequestOptions options = null, AllowedMentions allowedMentions = null,
|
||||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null,
|
||||||
=> WebhookClientHelper.SendMessageAsync(this, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, components, flags, threadId, threadName);
|
ulong[] appliedTags = null)
|
||||||
|
=> WebhookClientHelper.SendMessageAsync(this, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, components, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Modifies a message posted using this webhook.
|
/// Modifies a message posted using this webhook.
|
||||||
@@ -155,9 +156,10 @@ public class DiscordWebhookClient : IDisposable
|
|||||||
public Task<ulong> SendFileAsync(string filePath, string text, bool isTTS = false,
|
public Task<ulong> SendFileAsync(string filePath, string text, bool isTTS = false,
|
||||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||||
RequestOptions options = null, bool isSpoiler = false, AllowedMentions allowedMentions = null,
|
RequestOptions options = null, bool isSpoiler = false, AllowedMentions allowedMentions = null,
|
||||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null,
|
||||||
|
string threadName = null, ulong[] appliedTags = null)
|
||||||
=> WebhookClientHelper.SendFileAsync(this, filePath, text, isTTS, embeds, username, avatarUrl,
|
=> WebhookClientHelper.SendFileAsync(this, filePath, text, isTTS, embeds, username, avatarUrl,
|
||||||
allowedMentions, options, isSpoiler, components, flags, threadId, threadName);
|
allowedMentions, options, isSpoiler, components, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Sends a message to the channel for this webhook with an attachment.
|
/// Sends a message to the channel for this webhook with an attachment.
|
||||||
@@ -168,18 +170,19 @@ public class DiscordWebhookClient : IDisposable
|
|||||||
public Task<ulong> SendFileAsync(Stream stream, string filename, string text, bool isTTS = false,
|
public Task<ulong> SendFileAsync(Stream stream, string filename, string text, bool isTTS = false,
|
||||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||||
RequestOptions options = null, bool isSpoiler = false, AllowedMentions allowedMentions = null,
|
RequestOptions options = null, bool isSpoiler = false, AllowedMentions allowedMentions = null,
|
||||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null,
|
||||||
|
string threadName = null, ulong[] appliedTags = null)
|
||||||
=> WebhookClientHelper.SendFileAsync(this, stream, filename, text, isTTS, embeds, username,
|
=> WebhookClientHelper.SendFileAsync(this, stream, filename, text, isTTS, embeds, username,
|
||||||
avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId, threadName);
|
avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
/// <summary> Sends a message to the channel for this webhook with an attachment. </summary>
|
/// <summary> Sends a message to the channel for this webhook with an attachment. </summary>
|
||||||
/// <returns> Returns the ID of the created message. </returns>
|
/// <returns> Returns the ID of the created message. </returns>
|
||||||
public Task<ulong> SendFileAsync(FileAttachment attachment, string text, bool isTTS = false,
|
public Task<ulong> SendFileAsync(FileAttachment attachment, string text, bool isTTS = false,
|
||||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||||
RequestOptions options = null, AllowedMentions allowedMentions = null, MessageComponent components = null,
|
RequestOptions options = null, AllowedMentions allowedMentions = null, MessageComponent components = null,
|
||||||
MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null, ulong[] appliedTags = null)
|
||||||
=> WebhookClientHelper.SendFileAsync(this, attachment, text, isTTS, embeds, username,
|
=> WebhookClientHelper.SendFileAsync(this, attachment, text, isTTS, embeds, username,
|
||||||
avatarUrl, allowedMentions, components, options, flags, threadId, threadName);
|
avatarUrl, allowedMentions, components, options, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Sends a message to the channel for this webhook with an attachment.
|
/// Sends a message to the channel for this webhook with an attachment.
|
||||||
@@ -190,9 +193,9 @@ public class DiscordWebhookClient : IDisposable
|
|||||||
public Task<ulong> SendFilesAsync(IEnumerable<FileAttachment> attachments, string text, bool isTTS = false,
|
public Task<ulong> SendFilesAsync(IEnumerable<FileAttachment> attachments, string text, bool isTTS = false,
|
||||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||||
RequestOptions options = null, AllowedMentions allowedMentions = null, MessageComponent components = null,
|
RequestOptions options = null, AllowedMentions allowedMentions = null, MessageComponent components = null,
|
||||||
MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null, ulong[] appliedTags = null)
|
||||||
=> WebhookClientHelper.SendFilesAsync(this, attachments, text, isTTS, embeds, username, avatarUrl,
|
=> WebhookClientHelper.SendFilesAsync(this, attachments, text, isTTS, embeds, username, avatarUrl,
|
||||||
allowedMentions, components, options, flags, threadId, threadName);
|
allowedMentions, components, options, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Modifies the properties of this webhook.
|
/// Modifies the properties of this webhook.
|
||||||
|
|||||||
@@ -25,7 +25,8 @@ namespace Discord.Webhook
|
|||||||
|
|
||||||
public static async Task<ulong> SendMessageAsync(DiscordWebhookClient client,
|
public static async Task<ulong> SendMessageAsync(DiscordWebhookClient client,
|
||||||
string text, bool isTTS, IEnumerable<Embed> embeds, string username, string avatarUrl,
|
string text, bool isTTS, IEnumerable<Embed> embeds, string username, string avatarUrl,
|
||||||
AllowedMentions allowedMentions, RequestOptions options, MessageComponent components, MessageFlags flags, ulong? threadId = null, string threadName = null)
|
AllowedMentions allowedMentions, RequestOptions options, MessageComponent components,
|
||||||
|
MessageFlags flags, ulong? threadId = null, string threadName = null, ulong[] appliedTags = null)
|
||||||
{
|
{
|
||||||
var args = new CreateWebhookMessageParams
|
var args = new CreateWebhookMessageParams
|
||||||
{
|
{
|
||||||
@@ -48,6 +49,8 @@ namespace Discord.Webhook
|
|||||||
args.Components = components?.Components.Select(x => new API.ActionRowComponent(x)).ToArray();
|
args.Components = components?.Components.Select(x => new API.ActionRowComponent(x)).ToArray();
|
||||||
if (threadName is not null)
|
if (threadName is not null)
|
||||||
args.ThreadName = threadName;
|
args.ThreadName = threadName;
|
||||||
|
if (appliedTags != null)
|
||||||
|
args.AppliedTags = appliedTags;
|
||||||
|
|
||||||
if (flags is not MessageFlags.None and not MessageFlags.SuppressEmbeds)
|
if (flags is not MessageFlags.None and not MessageFlags.SuppressEmbeds)
|
||||||
throw new ArgumentException("The only valid MessageFlags are SuppressEmbeds and none.", nameof(flags));
|
throw new ArgumentException("The only valid MessageFlags are SuppressEmbeds and none.", nameof(flags));
|
||||||
@@ -132,27 +135,29 @@ namespace Discord.Webhook
|
|||||||
|
|
||||||
public static async Task<ulong> SendFileAsync(DiscordWebhookClient client, string filePath, string text, bool isTTS,
|
public static async Task<ulong> SendFileAsync(DiscordWebhookClient client, string filePath, string text, bool isTTS,
|
||||||
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions, RequestOptions options,
|
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions, RequestOptions options,
|
||||||
bool isSpoiler, MessageComponent components, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
bool isSpoiler, MessageComponent components, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null,
|
||||||
|
ulong[] appliedTags = null)
|
||||||
{
|
{
|
||||||
string filename = Path.GetFileName(filePath);
|
string filename = Path.GetFileName(filePath);
|
||||||
using (var file = File.OpenRead(filePath))
|
using (var file = File.OpenRead(filePath))
|
||||||
return await SendFileAsync(client, file, filename, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId, threadName).ConfigureAwait(false);
|
return await SendFileAsync(client, file, filename, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId, threadName, appliedTags).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Task<ulong> SendFileAsync(DiscordWebhookClient client, Stream stream, string filename, string text, bool isTTS,
|
public static Task<ulong> SendFileAsync(DiscordWebhookClient client, Stream stream, string filename, string text, bool isTTS,
|
||||||
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions, RequestOptions options, bool isSpoiler,
|
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions, RequestOptions options, bool isSpoiler,
|
||||||
MessageComponent components, MessageFlags flags, ulong? threadId, string threadName = null)
|
MessageComponent components, MessageFlags flags, ulong? threadId, string threadName = null, ulong[] appliedTags = null)
|
||||||
=> SendFileAsync(client, new FileAttachment(stream, filename, isSpoiler: isSpoiler), text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId, threadName);
|
=> SendFileAsync(client, new FileAttachment(stream, filename, isSpoiler: isSpoiler), text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
public static Task<ulong> SendFileAsync(DiscordWebhookClient client, FileAttachment attachment, string text, bool isTTS,
|
public static Task<ulong> SendFileAsync(DiscordWebhookClient client, FileAttachment attachment, string text, bool isTTS,
|
||||||
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions,
|
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions,
|
||||||
MessageComponent components, RequestOptions options, MessageFlags flags, ulong? threadId, string threadName = null)
|
MessageComponent components, RequestOptions options, MessageFlags flags, ulong? threadId, string threadName = null,
|
||||||
=> SendFilesAsync(client, new FileAttachment[] { attachment }, text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId, threadName);
|
ulong[] appliedTags = null)
|
||||||
|
=> SendFilesAsync(client, new FileAttachment[] { attachment }, text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId, threadName, appliedTags);
|
||||||
|
|
||||||
public static async Task<ulong> SendFilesAsync(DiscordWebhookClient client,
|
public static async Task<ulong> SendFilesAsync(DiscordWebhookClient client,
|
||||||
IEnumerable<FileAttachment> attachments, string text, bool isTTS, IEnumerable<Embed> embeds, string username,
|
IEnumerable<FileAttachment> attachments, string text, bool isTTS, IEnumerable<Embed> embeds, string username,
|
||||||
string avatarUrl, AllowedMentions allowedMentions, MessageComponent components, RequestOptions options,
|
string avatarUrl, AllowedMentions allowedMentions, MessageComponent components, RequestOptions options,
|
||||||
MessageFlags flags, ulong? threadId, string threadName = null)
|
MessageFlags flags, ulong? threadId, string threadName = null, ulong[] appliedTags = null)
|
||||||
{
|
{
|
||||||
embeds ??= Array.Empty<Embed>();
|
embeds ??= Array.Empty<Embed>();
|
||||||
|
|
||||||
@@ -196,7 +201,8 @@ namespace Discord.Webhook
|
|||||||
AllowedMentions = allowedMentions?.ToModel() ?? Optional<API.AllowedMentions>.Unspecified,
|
AllowedMentions = allowedMentions?.ToModel() ?? Optional<API.AllowedMentions>.Unspecified,
|
||||||
MessageComponents = components?.Components.Select(x => new API.ActionRowComponent(x)).ToArray() ?? Optional<API.ActionRowComponent[]>.Unspecified,
|
MessageComponents = components?.Components.Select(x => new API.ActionRowComponent(x)).ToArray() ?? Optional<API.ActionRowComponent[]>.Unspecified,
|
||||||
Flags = flags,
|
Flags = flags,
|
||||||
ThreadName = threadName
|
ThreadName = threadName,
|
||||||
|
AppliedTags = appliedTags
|
||||||
};
|
};
|
||||||
var msg = await client.ApiClient.UploadWebhookFileAsync(client.Webhook.Id, args, options, threadId).ConfigureAwait(false);
|
var msg = await client.ApiClient.UploadWebhookFileAsync(client.Webhook.Id, args, options, threadId).ConfigureAwait(false);
|
||||||
return msg.Id;
|
return msg.Id;
|
||||||
|
|||||||
Reference in New Issue
Block a user