diff --git a/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/ChannelSuspiciousUserBase.cs b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/ChannelSuspiciousUserBase.cs new file mode 100644 index 0000000..9a4c9f5 --- /dev/null +++ b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/ChannelSuspiciousUserBase.cs @@ -0,0 +1,40 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +/// +/// Channel suspicious user base class. +/// +public abstract class ChannelSuspiciousUserBase +{ + /// + /// The ID of the channel where the treatment for a suspicious user was updated. + /// + public string BroadcasterUserId { get; set; } = string.Empty; + /// + /// The display name of the channel where the treatment for a suspicious user was updated. + /// + public string BroadcasterUserName { get; set; } = string.Empty; + /// + /// The login of the channel where the treatment for a suspicious user was updated. + /// + public string BroadcasterUserLogin { get; set; } = string.Empty; + /// + /// The user ID of the user that sent the message. + /// + public string UserId { get; set; } = string.Empty; + /// + /// The user name of the user that sent the message. + /// + public string UserName { get; set; } = string.Empty; + /// + /// The user login of the user that sent the message. + /// + public string UserLogin { get; set; } = string.Empty; + /// + /// The status set for the suspicious user. Can be the following: “no_treatment”, “active_monitoring”, or “restricted” + /// + public string LowTrustStatus { get; set; } = string.Empty; +} diff --git a/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/Message.cs b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/Message.cs new file mode 100644 index 0000000..c241049 --- /dev/null +++ b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/Message.cs @@ -0,0 +1,21 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +public sealed class SuspiciousUserMessage +{ + /// + /// The UUID that identifies the message. + /// + public string MessageId { get; set; } = string.Empty; + /// + /// The chat message in plain text. + /// + public string Text { get; set; } = string.Empty; + /// + /// Ordered list of chat message fragments. + /// + public MessageFragment[] Fragments { get; set; } = []; +} diff --git a/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragment.cs b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragment.cs new file mode 100644 index 0000000..7e22c40 --- /dev/null +++ b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragment.cs @@ -0,0 +1,25 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +public sealed class MessageFragment +{ + /// + /// The type of message fragment. Possible values: -text -cheermote -emote + /// + public string Type { get; set; } = string.Empty; + /// + /// Message text in fragment. + /// + public string Text { get; set; } = string.Empty; + /// + /// Optional. Metadata pertaining to the cheermote. + /// + public FragmentCheermote? Cheermote { get; set; } + /// + /// Optional. Metadata pertaining to the emote. + /// + public FragmentEmote? Emote { get; set; } +} diff --git a/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragmentCheermote.cs b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragmentCheermote.cs new file mode 100644 index 0000000..13471bc --- /dev/null +++ b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragmentCheermote.cs @@ -0,0 +1,23 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +public sealed class FragmentCheermote +{ + /// + /// The name portion of the Cheermote string that you use in chat to cheer Bits. The full Cheermote string is the concatenation of {prefix} + {number of Bits}. + /// + /// For example, if the prefix is “Cheer” and you want to cheer 100 Bits, the full Cheermote string is Cheer100.When the Cheermote string is entered in chat, Twitch converts it to the image associated with the Bits tier that was cheered. + /// + public string Prefix { get; set; } = string.Empty; + /// + /// The amount of bits cheered. + /// + public int Bits { get; set; } = 0; + /// + /// The tier level of the cheermote. + /// + public int Tier { get; set; } = 0; +} diff --git a/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragmentEmote.cs b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragmentEmote.cs new file mode 100644 index 0000000..aab1ec8 --- /dev/null +++ b/TwitchLib.EventSub.Core/Models/ChannelSuspiciousUser/MessageFragmentEmote.cs @@ -0,0 +1,17 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +public sealed class FragmentEmote +{ + /// + /// An ID that uniquely identifies this emote. + /// + public string Id { get; set; } = string.Empty; + /// + /// An ID that identifies the emote set that the emote belongs to. + /// + public string EmoteSetId { get; set; } = string.Empty; +} diff --git a/TwitchLib.EventSub.Core/SubscriptionTypes/Channel/ChannelSuspiciousUserMessage.cs b/TwitchLib.EventSub.Core/SubscriptionTypes/Channel/ChannelSuspiciousUserMessage.cs new file mode 100644 index 0000000..764ccae --- /dev/null +++ b/TwitchLib.EventSub.Core/SubscriptionTypes/Channel/ChannelSuspiciousUserMessage.cs @@ -0,0 +1,27 @@ +using System; +using System.Collections.Generic; +using System.Diagnostics; +using System.Text; +using TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +namespace TwitchLib.EventSub.Core.SubscriptionTypes.Channel; + +public sealed class ChannelSuspiciousUserMessage : ChannelSuspiciousUserBase +{ + /// + /// A list of channel IDs where the suspicious user is also banned. + /// + public string[] SharedBanChannelIds { get; set; } = []; + /// + /// User types (if any) that apply to the suspicious user, can be “manually_added”, “ban_evader_detector”, or “shared_channel_ban”. + /// + public string[] Types { get; set; } = []; + /// + /// A ban evasion likelihood value (if any) that as been applied to the user automatically by Twitch, can be “unknown”, “possible”, or “likely”. + /// + public string BanEvasionEvaluation { get; set; } = string.Empty; + /// + /// The structured chat message. + /// + public SuspiciousUserMessage Message { get; set; } = new SuspiciousUserMessage(); +} diff --git a/TwitchLib.EventSub.Core/SubscriptionTypes/Channel/ChannelSuspiciousUserUpdate.cs b/TwitchLib.EventSub.Core/SubscriptionTypes/Channel/ChannelSuspiciousUserUpdate.cs new file mode 100644 index 0000000..bc81356 --- /dev/null +++ b/TwitchLib.EventSub.Core/SubscriptionTypes/Channel/ChannelSuspiciousUserUpdate.cs @@ -0,0 +1,22 @@ +using System; +using System.Collections.Generic; +using System.Text; +using TwitchLib.EventSub.Core.Models.ChannelSuspiciousUser; + +namespace TwitchLib.EventSub.Core.SubscriptionTypes.Channel; + +public sealed class ChannelSuspiciousUserUpdate : ChannelSuspiciousUserBase +{ + /// + /// The ID of the moderator that updated the treatment for a suspicious user. + /// + public string ModeratorUserId { get; set; } = string.Empty; + /// + /// The display name of the moderator that updated the treatment for a suspicious user. + /// + public string ModeratorUserName { get; set; } = string.Empty; + /// + /// The login of the moderator that updated the treatment for a suspicious user. + /// + public string ModeratorUserLogin { get; set; } = string.Empty; +}