#![doc(alias = "automod.terms.update")]
use super::*;
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize)]
#[cfg_attr(feature = "typed-builder", derive(typed_builder::TypedBuilder))]
#[cfg_attr(feature = "deny_unknown_fields", serde(deny_unknown_fields))]
#[non_exhaustive]
pub struct AutomodTermsUpdateV1 {
#[cfg_attr(feature = "typed-builder", builder(setter(into)))]
pub broadcaster_user_id: types::UserId,
#[cfg_attr(feature = "typed-builder", builder(setter(into)))]
pub moderator_user_id: types::UserId,
}
impl AutomodTermsUpdateV1 {
pub fn new(
broadcaster_user_id: impl Into<types::UserId>,
moderator_user_id: impl Into<types::UserId>,
) -> Self {
Self {
broadcaster_user_id: broadcaster_user_id.into(),
moderator_user_id: moderator_user_id.into(),
}
}
}
impl EventSubscription for AutomodTermsUpdateV1 {
type Payload = AutomodTermsUpdateV1Payload;
const EVENT_TYPE: EventType = EventType::AutomodTermsUpdate;
#[cfg(feature = "twitch_oauth2")]
const SCOPE: twitch_oauth2::Validator =
twitch_oauth2::validator![twitch_oauth2::Scope::ModeratorManageAutoMod];
const VERSION: &'static str = "1";
}
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize)]
#[cfg_attr(feature = "deny_unknown_fields", serde(deny_unknown_fields))]
#[non_exhaustive]
pub struct AutomodTermsUpdateV1Payload {
pub broadcaster_user_id: types::UserId,
pub broadcaster_user_login: types::UserName,
pub broadcaster_user_name: types::DisplayName,
pub moderator_user_id: types::UserId,
pub moderator_user_login: types::UserName,
pub moderator_user_name: types::DisplayName,
pub action: AutomodTermAction,
pub from_automod: bool,
pub terms: Vec<String>,
}
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize)]
#[non_exhaustive]
#[serde(rename_all = "snake_case")]
pub enum AutomodTermAction {
AddPermitted,
RemovePermitted,
AddBlocked,
RemoveBlocked,
#[serde(untagged)]
Unknown(String),
}
#[cfg(test)]
#[test]
fn parse_payload() {
use crate::eventsub::{Event, Message};
let payload = r##"
{
"subscription": {
"id": "480cfe69-7aea-4527-b0a7-9704a0bf7294",
"status": "enabled",
"type": "automod.terms.update",
"version": "1",
"condition": {
"broadcaster_user_id": "129546453",
"moderator_user_id": "129546453"
},
"transport": {
"method": "websocket",
"session_id": "AgoQZ12VWLotRG6u3pudLlbhvhIGY2VsbC1j"
},
"created_at": "2024-11-03T11:52:05.699721918Z",
"cost": 0
},
"event": {
"broadcaster_user_id": "129546453",
"broadcaster_user_login": "nerixyz",
"broadcaster_user_name": "nerixyz",
"moderator_user_id": "129546453",
"moderator_user_login": "nerixyz",
"moderator_user_name": "nerixyz",
"action": "add_permitted",
"from_automod": true,
"terms": [
"boobs"
]
}
}
"##;
let val = Event::parse(payload).unwrap();
crate::tests::roundtrip(&val);
let Event::AutomodTermsUpdateV1(val) = val else {
panic!("invalid event type");
};
let Message::Notification(notif) = val.message else {
panic!("invalid terms type");
};
assert_eq!(notif.broadcaster_user_id.as_str(), "129546453");
assert!(notif.from_automod);
assert_eq!(notif.action, AutomodTermAction::AddPermitted);
assert_eq!(notif.terms.len(), 1);
assert_eq!(notif.terms[0], "boobs");
}