#![doc(alias = "channel.guest_star_session.end")]
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 ChannelGuestStarSessionEndBeta {
#[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 ChannelGuestStarSessionEndBeta {
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 ChannelGuestStarSessionEndBeta {
type Payload = ChannelGuestStarSessionEndBetaPayload;
const EVENT_TYPE: EventType = EventType::ChannelGuestStarSessionEnd;
#[cfg(feature = "twitch_oauth2")]
const SCOPE: twitch_oauth2::Validator = twitch_oauth2::validator![any(
twitch_oauth2::Scope::ChannelReadGuestStar,
twitch_oauth2::Scope::ChannelManageGuestStar,
twitch_oauth2::Scope::ModeratorReadGuestStar,
twitch_oauth2::Scope::ModeratorManageGuestStar,
)];
const VERSION: &'static str = "beta";
}
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize)]
#[cfg_attr(feature = "deny_unknown_fields", serde(deny_unknown_fields))]
#[non_exhaustive]
pub struct ChannelGuestStarSessionEndBetaPayload {
pub broadcaster_user_id: types::UserId,
pub broadcaster_user_login: types::UserName,
pub broadcaster_user_name: types::DisplayName,
pub session_id: types::GuestStarSessionId,
pub started_at: types::Timestamp,
pub ended_at: types::Timestamp,
pub host_user_id: types::UserId,
pub host_user_login: types::UserName,
pub host_user_name: types::DisplayName,
}
#[cfg(test)]
#[test]
fn parse_payload() {
use crate::eventsub::{Event, Message};
let payload = r##"
{
"subscription": {
"id": "f1c2a387-161a-49f9-a165-0f21d7a4e1c4",
"type": "channel.guest_star_session.end",
"version": "beta",
"status": "enabled",
"cost": 0,
"condition": {
"broadcaster_user_id": "1337",
"moderator_user_id": "1338"
},
"transport": {
"method": "webhook",
"callback": "https://example.com/webhooks/callback"
},
"created_at": "2023-04-11T10:11:22.123Z"
},
"event": {
"broadcaster_user_id": "1337",
"broadcaster_user_name": "Cool_User",
"broadcaster_user_login": "cool_user",
"host_user_id": "1338",
"host_user_name": "Cool_Mod",
"host_user_login": "cool_mod",
"session_id": "2KFRQbFtpmfyD3IevNRnCzOPRJI",
"started_at": "2023-04-11T16:20:03.17106713Z",
"ended_at": "2023-04-11T17:51:29.153485Z"
}
}
"##;
let val = Event::parse(payload).unwrap();
crate::tests::roundtrip(&val);
let Event::ChannelGuestStarSessionEndBeta(val) = val else {
panic!("invalid event type");
};
let Message::Notification(notif) = val.message else {
panic!("invalid settings type");
};
assert_eq!(notif.broadcaster_user_id.as_str(), "1337");
assert_eq!(notif.host_user_id.as_str(), "1338");
assert_eq!(notif.session_id.as_str(), "2KFRQbFtpmfyD3IevNRnCzOPRJI");
assert_eq!(notif.started_at.as_str(), "2023-04-11T16:20:03.17106713Z");
assert_eq!(notif.ended_at.as_str(), "2023-04-11T17:51:29.153485Z");
}