use super::*;
use helix::RequestDelete;
#[derive(PartialEq, typed_builder::TypedBuilder, Deserialize, Serialize, Clone, Debug)]
#[non_exhaustive]
pub struct RemoveBlockedTermRequest {
#[builder(setter(into))]
pub broadcaster_id: types::UserId,
#[builder(setter(into))]
pub moderator_id: types::UserId,
#[builder(setter(into))]
pub id: types::BlockedTermId,
}
#[derive(PartialEq, Deserialize, Serialize, Debug, Clone)]
#[non_exhaustive]
pub enum RemoveBlockedTerm {
Success,
}
impl Request for RemoveBlockedTermRequest {
type Response = RemoveBlockedTerm;
#[cfg(feature = "twitch_oauth2")]
const OPT_SCOPE: &'static [twitch_oauth2::Scope] = &[];
const PATH: &'static str = "moderation/blocked_terms";
#[cfg(feature = "twitch_oauth2")]
const SCOPE: &'static [twitch_oauth2::Scope] =
&[twitch_oauth2::Scope::ModeratorManageBlockedTerms];
}
impl RequestDelete for RemoveBlockedTermRequest {
fn parse_inner_response(
request: Option<Self>,
uri: &http::Uri,
response: &str,
status: http::StatusCode,
) -> Result<helix::Response<Self, Self::Response>, helix::HelixRequestDeleteError>
where
Self: Sized,
{
match status {
http::StatusCode::NO_CONTENT => Ok(helix::Response {
data: RemoveBlockedTerm::Success,
pagination: None,
request,
total: None,
other: None,
}),
_ => Err(helix::HelixRequestDeleteError::InvalidResponse {
reason: "unexpected status",
response: response.to_string(),
status,
uri: uri.clone(),
}),
}
}
}
#[cfg(test)]
#[test]
fn test_request() {
use helix::*;
let req = RemoveBlockedTermRequest::builder()
.broadcaster_id("1234")
.moderator_id("5678")
.id("c9fc79b8-0f63-4ef7-9d38-efd811e74ac2")
.build();
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/moderation/blocked_terms?broadcaster_id=1234&moderator_id=5678&id=c9fc79b8-0f63-4ef7-9d38-efd811e74ac2"
);
dbg!(RemoveBlockedTermRequest::parse_response(Some(req), &uri, http_response).unwrap());
}