use super::*;
use helix::RequestPatch;
#[derive(PartialEq, Eq, Deserialize, Serialize, Clone, Debug)]
#[cfg_attr(feature = "typed-builder", derive(typed_builder::TypedBuilder))]
#[must_use]
#[non_exhaustive]
pub struct UpdateChannelStreamScheduleRequest<'a> {
#[cfg_attr(feature = "typed-builder", builder(setter(into)))]
#[cfg_attr(feature = "deser_borrow", serde(borrow = "'a"))]
pub broadcaster_id: Cow<'a, types::UserIdRef>,
#[cfg_attr(feature = "typed-builder", builder(default, setter(into)))]
pub is_vacation_enabled: Option<bool>,
#[cfg_attr(feature = "typed-builder", builder(default, setter(into)))]
#[cfg_attr(feature = "deser_borrow", serde(borrow = "'a"))]
pub vacation_start_time: Option<Cow<'a, types::TimestampRef>>,
#[cfg_attr(feature = "typed-builder", builder(default, setter(into)))]
#[cfg_attr(feature = "deser_borrow", serde(borrow = "'a"))]
pub vacation_end_time: Option<Cow<'a, types::TimestampRef>>,
#[cfg_attr(feature = "typed-builder", builder(default, setter(into)))]
#[cfg_attr(feature = "deser_borrow", serde(borrow = "'a"))]
pub timezone: Option<Cow<'a, str>>,
}
impl<'a> UpdateChannelStreamScheduleRequest<'a> {
pub fn broadcaster_id(broadcaster_id: impl types::IntoCow<'a, types::UserIdRef> + 'a) -> Self {
Self {
broadcaster_id: broadcaster_id.into_cow(),
is_vacation_enabled: Default::default(),
vacation_start_time: Default::default(),
vacation_end_time: Default::default(),
timezone: Default::default(),
}
}
}
#[derive(PartialEq, Eq, Deserialize, Serialize, Debug, Clone)]
#[cfg_attr(feature = "deny_unknown_fields", serde(deny_unknown_fields))]
#[non_exhaustive]
pub enum UpdateChannelStreamSchedule {
Success,
}
impl Request for UpdateChannelStreamScheduleRequest<'_> {
type Response = UpdateChannelStreamSchedule;
const PATH: &'static str = "schedule/settings";
#[cfg(feature = "twitch_oauth2")]
const SCOPE: twitch_oauth2::Validator =
twitch_oauth2::validator![twitch_oauth2::Scope::ChannelManageSchedule];
}
impl RequestPatch for UpdateChannelStreamScheduleRequest<'_> {
type Body = helix::EmptyBody;
fn parse_inner_response(
request: Option<Self>,
uri: &http::Uri,
response: &str,
status: http::StatusCode,
) -> Result<helix::Response<Self, Self::Response>, helix::HelixRequestPatchError>
where
Self: Sized,
{
let resp = match status {
http::StatusCode::OK | http::StatusCode::NO_CONTENT => {
UpdateChannelStreamSchedule::Success
}
_ => {
return Err(helix::HelixRequestPatchError::InvalidResponse {
reason: "unexpected status code",
response: response.to_string(),
status,
uri: uri.clone(),
})
}
};
Ok(helix::Response::with_data(resp, request))
}
}
#[cfg(test)]
#[test]
fn test_request() {
use std::convert::TryFrom;
use helix::*;
let start = types::Timestamp::try_from("2021-05-16T00:00:00Z").unwrap();
let end = types::Timestamp::try_from("2021-05-23T00:00:00Z").unwrap();
let req = UpdateChannelStreamScheduleRequest {
is_vacation_enabled: Some(true),
vacation_start_time: Some(types::IntoCow::into_cow(start)),
vacation_end_time: Some(types::IntoCow::into_cow(end)),
timezone: Some("America/New_York".into()),
..UpdateChannelStreamScheduleRequest::broadcaster_id("141981764")
};
let body = helix::EmptyBody;
dbg!(req.create_request(body, "token", "clientid").unwrap());
let data = br"".to_vec();
let http_response = http::Response::builder().status(204).body(data).unwrap();
let uri = req.get_uri().unwrap();
assert_eq!(
uri.to_string(),
"https://api.twitch.tv/helix/schedule/settings?broadcaster_id=141981764&is_vacation_enabled=true&vacation_start_time=2021-05-16T00%3A00%3A00Z&vacation_end_time=2021-05-23T00%3A00%3A00Z&timezone=America%2FNew_York"
);
dbg!(
UpdateChannelStreamScheduleRequest::parse_response(Some(req), &uri, http_response).unwrap()
);
}