Create forum posts with DiscordWebhookClient (#2603)
This commit is contained in:
@@ -42,6 +42,9 @@ namespace Discord.API.Rest
|
||||
[JsonProperty("file")]
|
||||
public Optional<MultipartFile> File { get; set; }
|
||||
|
||||
[JsonProperty("thread_name")]
|
||||
public Optional<string> ThreadName { get; set; }
|
||||
|
||||
public IReadOnlyDictionary<string, object> ToDictionary()
|
||||
{
|
||||
var d = new Dictionary<string, object>();
|
||||
@@ -70,6 +73,8 @@ namespace Discord.API.Rest
|
||||
payload["allowed_mentions"] = AllowedMentions.Value;
|
||||
if (Components.IsSpecified)
|
||||
payload["components"] = Components.Value;
|
||||
if (ThreadName.IsSpecified)
|
||||
payload["thread_name"] = ThreadName.Value;
|
||||
|
||||
var json = new StringBuilder();
|
||||
using (var text = new StringWriter(json))
|
||||
|
||||
@@ -22,6 +22,7 @@ namespace Discord.API.Rest
|
||||
public Optional<AllowedMentions> AllowedMentions { get; set; }
|
||||
public Optional<ActionRowComponent[]> MessageComponents { get; set; }
|
||||
public Optional<MessageFlags> Flags { get; set; }
|
||||
public Optional<string> ThreadName { get; set; }
|
||||
|
||||
public UploadWebhookFileParams(params FileAttachment[] files)
|
||||
{
|
||||
@@ -51,6 +52,8 @@ namespace Discord.API.Rest
|
||||
payload["allowed_mentions"] = AllowedMentions.Value;
|
||||
if (Flags.IsSpecified)
|
||||
payload["flags"] = Flags.Value;
|
||||
if (ThreadName.IsSpecified)
|
||||
payload["thread_name"] = ThreadName.Value;
|
||||
|
||||
List<object> attachments = new();
|
||||
|
||||
|
||||
@@ -88,8 +88,8 @@ namespace Discord.Webhook
|
||||
/// <returns> Returns the ID of the created message. </returns>
|
||||
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,
|
||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null)
|
||||
=> WebhookClientHelper.SendMessageAsync(this, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, components, flags, threadId);
|
||||
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);
|
||||
|
||||
/// <summary>
|
||||
/// Modifies a message posted using this webhook.
|
||||
@@ -125,35 +125,35 @@ namespace Discord.Webhook
|
||||
public Task<ulong> SendFileAsync(string filePath, string text, bool isTTS = false,
|
||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||
RequestOptions options = null, bool isSpoiler = false, AllowedMentions allowedMentions = null,
|
||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null)
|
||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
||||
=> WebhookClientHelper.SendFileAsync(this, filePath, text, isTTS, embeds, username, avatarUrl,
|
||||
allowedMentions, options, isSpoiler, components, flags, threadId);
|
||||
allowedMentions, options, isSpoiler, components, flags, threadId, threadName);
|
||||
/// <summary> Sends a message to the channel for this webhook with an attachment. </summary>
|
||||
/// <returns> Returns the ID of the created message. </returns>
|
||||
public Task<ulong> SendFileAsync(Stream stream, string filename, string text, bool isTTS = false,
|
||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||
RequestOptions options = null, bool isSpoiler = false, AllowedMentions allowedMentions = null,
|
||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null)
|
||||
MessageComponent components = null, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
||||
=> WebhookClientHelper.SendFileAsync(this, stream, filename, text, isTTS, embeds, username,
|
||||
avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId);
|
||||
avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId, threadName);
|
||||
|
||||
/// <summary> Sends a message to the channel for this webhook with an attachment. </summary>
|
||||
/// <returns> Returns the ID of the created message. </returns>
|
||||
public Task<ulong> SendFileAsync(FileAttachment attachment, string text, bool isTTS = false,
|
||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||
RequestOptions options = null, AllowedMentions allowedMentions = null, MessageComponent components = null,
|
||||
MessageFlags flags = MessageFlags.None, ulong? threadId = null)
|
||||
MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
||||
=> WebhookClientHelper.SendFileAsync(this, attachment, text, isTTS, embeds, username,
|
||||
avatarUrl, allowedMentions, components, options, flags, threadId);
|
||||
avatarUrl, allowedMentions, components, options, flags, threadId, threadName);
|
||||
|
||||
/// <summary> Sends a message to the channel for this webhook with an attachment. </summary>
|
||||
/// <returns> Returns the ID of the created message. </returns>
|
||||
public Task<ulong> SendFilesAsync(IEnumerable<FileAttachment> attachments, string text, bool isTTS = false,
|
||||
IEnumerable<Embed> embeds = null, string username = null, string avatarUrl = null,
|
||||
RequestOptions options = null, AllowedMentions allowedMentions = null, MessageComponent components = null,
|
||||
MessageFlags flags = MessageFlags.None, ulong? threadId = null)
|
||||
MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
||||
=> WebhookClientHelper.SendFilesAsync(this, attachments, text, isTTS, embeds, username, avatarUrl,
|
||||
allowedMentions, components, options, flags, threadId);
|
||||
allowedMentions, components, options, flags, threadId, threadName);
|
||||
|
||||
|
||||
/// <summary> Modifies the properties of this webhook. </summary>
|
||||
|
||||
@@ -1,10 +1,12 @@
|
||||
using Discord.API.Rest;
|
||||
using Discord.Rest;
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
using ImageModel = Discord.API.Image;
|
||||
using WebhookModel = Discord.API.Webhook;
|
||||
|
||||
@@ -22,7 +24,7 @@ namespace Discord.Webhook
|
||||
}
|
||||
public static async Task<ulong> SendMessageAsync(DiscordWebhookClient client,
|
||||
string text, bool isTTS, IEnumerable<Embed> embeds, string username, string avatarUrl,
|
||||
AllowedMentions allowedMentions, RequestOptions options, MessageComponent components, MessageFlags flags, ulong? threadId = null)
|
||||
AllowedMentions allowedMentions, RequestOptions options, MessageComponent components, MessageFlags flags, ulong? threadId = null, string threadName = null)
|
||||
{
|
||||
var args = new CreateWebhookMessageParams
|
||||
{
|
||||
@@ -41,6 +43,8 @@ namespace Discord.Webhook
|
||||
args.AllowedMentions = allowedMentions.ToModel();
|
||||
if (components != null)
|
||||
args.Components = components?.Components.Select(x => new API.ActionRowComponent(x)).ToArray();
|
||||
if (threadName is not null)
|
||||
args.ThreadName = threadName;
|
||||
|
||||
if (flags is not MessageFlags.None and not MessageFlags.SuppressEmbeds)
|
||||
throw new ArgumentException("The only valid MessageFlags are SuppressEmbeds and none.", nameof(flags));
|
||||
@@ -98,32 +102,35 @@ namespace Discord.Webhook
|
||||
await client.ApiClient.ModifyWebhookMessageAsync(client.Webhook.Id, messageId, apiArgs, options, threadId)
|
||||
.ConfigureAwait(false);
|
||||
}
|
||||
|
||||
public static async Task DeleteMessageAsync(DiscordWebhookClient client, ulong messageId, RequestOptions options, ulong? threadId)
|
||||
{
|
||||
await client.ApiClient.DeleteWebhookMessageAsync(client.Webhook.Id, messageId, options, threadId).ConfigureAwait(false);
|
||||
}
|
||||
|
||||
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,
|
||||
bool isSpoiler, MessageComponent components, MessageFlags flags = MessageFlags.None, ulong? threadId = null)
|
||||
bool isSpoiler, MessageComponent components, MessageFlags flags = MessageFlags.None, ulong? threadId = null, string threadName = null)
|
||||
{
|
||||
string filename = Path.GetFileName(filePath);
|
||||
using (var file = File.OpenRead(filePath))
|
||||
return await SendFileAsync(client, file, filename, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId).ConfigureAwait(false);
|
||||
return await SendFileAsync(client, file, filename, text, isTTS, embeds, username, avatarUrl, allowedMentions, options, isSpoiler, components, flags, threadId, threadName).ConfigureAwait(false);
|
||||
}
|
||||
|
||||
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,
|
||||
MessageComponent components, MessageFlags flags, ulong? threadId)
|
||||
=> SendFileAsync(client, new FileAttachment(stream, filename, isSpoiler: isSpoiler), text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId);
|
||||
MessageComponent components, MessageFlags flags, ulong? threadId, string threadName = null)
|
||||
=> SendFileAsync(client, new FileAttachment(stream, filename, isSpoiler: isSpoiler), text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId, threadName);
|
||||
|
||||
public static Task<ulong> SendFileAsync(DiscordWebhookClient client, FileAttachment attachment, string text, bool isTTS,
|
||||
IEnumerable<Embed> embeds, string username, string avatarUrl, AllowedMentions allowedMentions,
|
||||
MessageComponent components, RequestOptions options, MessageFlags flags, ulong? threadId)
|
||||
=> SendFilesAsync(client, new FileAttachment[] { attachment }, text, isTTS, embeds, username, avatarUrl, allowedMentions, components, options, flags, threadId);
|
||||
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);
|
||||
|
||||
public static async Task<ulong> SendFilesAsync(DiscordWebhookClient client,
|
||||
IEnumerable<FileAttachment> attachments, string text, bool isTTS, IEnumerable<Embed> embeds, string username,
|
||||
string avatarUrl, AllowedMentions allowedMentions, MessageComponent components, RequestOptions options,
|
||||
MessageFlags flags, ulong? threadId)
|
||||
MessageFlags flags, ulong? threadId, string threadName = null)
|
||||
{
|
||||
embeds ??= Array.Empty<Embed>();
|
||||
|
||||
@@ -164,7 +171,8 @@ namespace Discord.Webhook
|
||||
Embeds = embeds.Any() ? embeds.Select(x => x.ToModel()).ToArray() : Optional<API.Embed[]>.Unspecified,
|
||||
AllowedMentions = allowedMentions?.ToModel() ?? Optional<API.AllowedMentions>.Unspecified,
|
||||
MessageComponents = components?.Components.Select(x => new API.ActionRowComponent(x)).ToArray() ?? Optional<API.ActionRowComponent[]>.Unspecified,
|
||||
Flags = flags
|
||||
Flags = flags,
|
||||
ThreadName = threadName
|
||||
};
|
||||
var msg = await client.ApiClient.UploadWebhookFileAsync(client.Webhook.Id, args, options, threadId).ConfigureAwait(false);
|
||||
return msg.Id;
|
||||
|
||||
Reference in New Issue
Block a user