| @@ -140,6 +140,18 @@ namespace Discord | |||||
| /// </returns> | /// </returns> | ||||
| MessageApplication Application { get; } | MessageApplication Application { get; } | ||||
| /// <summary> | |||||
| /// Gets the reference to the original message if it was crossposted. | |||||
| /// </summary> | |||||
| /// <remarks> | |||||
| /// Sent with Cross-posted messages, meaning they were published from news channels | |||||
| /// and received by subscriber channels. | |||||
| /// </remarks> | |||||
| /// <returns> | |||||
| /// A message's reference, if any is associated. | |||||
| /// </returns> | |||||
| MessageReference Reference { get; } | |||||
| /// <summary> | /// <summary> | ||||
| /// Gets all reactions included in this message. | /// Gets all reactions included in this message. | ||||
| /// </summary> | /// </summary> | ||||
| @@ -0,0 +1,34 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Diagnostics; | |||||
| using System.Linq; | |||||
| using System.Text; | |||||
| using System.Threading.Tasks; | |||||
| namespace Discord | |||||
| { | |||||
| /// <summary> | |||||
| /// Contains the IDs sent from a crossposted message. | |||||
| /// </summary> | |||||
| [DebuggerDisplay(@"{DebuggerDisplay,nq}")] | |||||
| public class MessageReference | |||||
| { | |||||
| /// <summary> | |||||
| /// Gets the Message ID of the original message. | |||||
| /// </summary> | |||||
| public ulong? MessageId { get; internal set; } | |||||
| /// <summary> | |||||
| /// Gets the Channel ID of the original message. | |||||
| /// </summary> | |||||
| public ulong ChannelId { get; internal set; } | |||||
| /// <summary> | |||||
| /// Gets the Guild ID of the original message. | |||||
| /// </summary> | |||||
| public ulong? GuildId { get; internal set; } | |||||
| public override string ToString() | |||||
| => $"Guild: {GuildId}, Channel: {ChannelId}, Message: {MessageId}"; | |||||
| } | |||||
| } | |||||
| @@ -50,6 +50,8 @@ namespace Discord.API | |||||
| // sent with Rich Presence-related chat embeds | // sent with Rich Presence-related chat embeds | ||||
| [JsonProperty("application")] | [JsonProperty("application")] | ||||
| public Optional<MessageApplication> Application { get; set; } | public Optional<MessageApplication> Application { get; set; } | ||||
| [JsonProperty("message_reference")] | |||||
| public Optional<MessageReference> Reference { get; set; } | |||||
| [JsonProperty("flags")] | [JsonProperty("flags")] | ||||
| public Optional<MessageFlags> Flags { get; set; } | public Optional<MessageFlags> Flags { get; set; } | ||||
| } | } | ||||
| @@ -0,0 +1,16 @@ | |||||
| using Newtonsoft.Json; | |||||
| namespace Discord.API | |||||
| { | |||||
| internal class MessageReference | |||||
| { | |||||
| [JsonProperty("message_id")] | |||||
| public ulong? MessageId { get; set; } | |||||
| [JsonProperty("channel_id")] | |||||
| public ulong ChannelId { get; set; } | |||||
| [JsonProperty("guild_id")] | |||||
| public ulong? GuildId { get; set; } | |||||
| } | |||||
| } | |||||
| @@ -62,6 +62,8 @@ namespace Discord.Rest | |||||
| public MessageActivity Activity { get; private set; } | public MessageActivity Activity { get; private set; } | ||||
| /// <inheritdoc /> | /// <inheritdoc /> | ||||
| public MessageApplication Application { get; private set; } | public MessageApplication Application { get; private set; } | ||||
| /// <inheritdoc /> | |||||
| public MessageReference Reference { get; private set; } | |||||
| internal RestMessage(BaseDiscordClient discord, ulong id, IMessageChannel channel, IUser author, MessageSource source) | internal RestMessage(BaseDiscordClient discord, ulong id, IMessageChannel channel, IUser author, MessageSource source) | ||||
| : base(discord, id) | : base(discord, id) | ||||
| @@ -108,6 +110,17 @@ namespace Discord.Rest | |||||
| }; | }; | ||||
| } | } | ||||
| if(model.Reference.IsSpecified) | |||||
| { | |||||
| // Creates a new Reference from the API model | |||||
| Reference = new MessageReference | |||||
| { | |||||
| GuildId = model.Reference.Value.GuildId, | |||||
| ChannelId = model.Reference.Value.ChannelId, | |||||
| MessageId = model.Reference.Value.MessageId | |||||
| }; | |||||
| } | |||||
| if (model.Reactions.IsSpecified) | if (model.Reactions.IsSpecified) | ||||
| { | { | ||||
| var value = model.Reactions.Value; | var value = model.Reactions.Value; | ||||
| @@ -53,6 +53,9 @@ namespace Discord.WebSocket | |||||
| /// <inheritdoc /> | /// <inheritdoc /> | ||||
| public MessageApplication Application { get; private set; } | public MessageApplication Application { get; private set; } | ||||
| /// <inheritdoc /> | |||||
| public MessageReference Reference { get; private set; } | |||||
| /// <summary> | /// <summary> | ||||
| /// Returns all attachments included in this message. | /// Returns all attachments included in this message. | ||||
| /// </summary> | /// </summary> | ||||
| @@ -140,6 +143,17 @@ namespace Discord.WebSocket | |||||
| PartyId = model.Activity.Value.PartyId.Value | PartyId = model.Activity.Value.PartyId.Value | ||||
| }; | }; | ||||
| } | } | ||||
| if (model.Reference.IsSpecified) | |||||
| { | |||||
| // Creates a new Reference from the API model | |||||
| Reference = new MessageReference | |||||
| { | |||||
| GuildId = model.Reference.Value.GuildId, | |||||
| ChannelId = model.Reference.Value.ChannelId, | |||||
| MessageId = model.Reference.Value.MessageId | |||||
| }; | |||||
| } | |||||
| } | } | ||||
| /// <inheritdoc /> | /// <inheritdoc /> | ||||