zai-rs 0.1.15

一个 Rust SDK, 用于调用 智普AI API
Documentation
//! # Content Moderation API
//!
//! This module provides the content moderation client for analyzing text,
//! image, audio, and video content for safety risks.

use super::models::*;
use crate::client::http::HttpClient;

/// Content moderation client.
///
/// This client provides functionality to moderate content for safety risks,
/// supporting text, image, audio, and video formats.
///
/// ## Examples
///
/// ```rust,ignore
/// let api_key = "your-api-key".to_string();
/// let moderation = Moderation::new_text("审核内容安全样例字符串。", api_key);
/// let result = moderation.send().await?;
/// ```
pub struct Moderation {
    /// API key for authentication
    pub key: String,
    /// Moderation request body
    body: ModerationRequest,
}

impl Moderation {
    /// Creates a new moderation request with text content.
    ///
    /// ## Arguments
    ///
    /// * `text` - The text content to moderate (max 2000 characters)
    /// * `key` - API key for authentication
    ///
    /// ## Returns
    ///
    /// A new `Moderation` instance configured for text moderation.
    pub fn new_text(text: impl Into<String>, key: String) -> Self {
        let body = ModerationRequest::new_text(text);
        Self { body, key }
    }

    /// Creates a new moderation request with multimedia content.
    ///
    /// ## Arguments
    ///
    /// * `content_type` - The type of multimedia content (image, audio, video)
    /// * `url` - URL to the multimedia content
    /// * `key` - API key for authentication
    ///
    /// ## Returns
    ///
    /// A new `Moderation` instance configured for multimedia moderation.
    pub fn new_multimedia(content_type: MediaType, url: impl Into<String>, key: String) -> Self {
        let body = ModerationRequest::new_multimedia(content_type, url);
        Self { body, key }
    }

    /// Gets mutable access to the request body for further customization.
    pub fn body_mut(&mut self) -> &mut ModerationRequest {
        &mut self.body
    }

    pub fn validate(&self) -> crate::ZaiResult<()> {
        self.body
            .validate()
            .map_err(crate::client::error::ZaiError::from)?;
        Ok(())
    }

    /// Sends the moderation request and returns the structured response.
    ///
    /// This method automatically validates the request before sending.
    ///
    /// ## Returns
    ///
    /// A `ModerationResponse` containing the moderation results and usage
    /// statistics.
    pub async fn send(&self) -> crate::ZaiResult<ModerationResponse> {
        self.validate()?;

        let resp: reqwest::Response = self.post().await?;

        let parsed = resp.json::<ModerationResponse>().await?;

        Ok(parsed)
    }
}

impl HttpClient for Moderation {
    type Body = ModerationRequest;
    type ApiUrl = &'static str;
    type ApiKey = String;

    /// Returns the Zhipu AI moderation API endpoint URL.
    fn api_url(&self) -> &Self::ApiUrl {
        &"https://open.bigmodel.cn/api/paas/v4/moderations"
    }

    fn api_key(&self) -> &Self::ApiKey {
        &self.key
    }

    fn body(&self) -> &Self::Body {
        &self.body
    }
}