shrike 0.1.6

AT Protocol library for Rust
Documentation
// Code generated by lexgen. DO NOT EDIT.

#[derive(Debug, Clone, serde::Serialize, serde::Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct QueueCreateQueueInput {
    /// Collection name for record subjects. Required if subjectTypes includes 'record'.
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub collection: Option<crate::syntax::Nsid>,
    /// Optional description of the queue
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub description: Option<String>,
    /// Display name for the queue (must be unique)
    pub name: String,
    /// Report reason types (fully qualified NSIDs)
    #[serde(default, skip_serializing_if = "Vec::is_empty")]
    pub report_types: Vec<String>,
    /// Subject types this queue accepts
    #[serde(default, skip_serializing_if = "Vec::is_empty")]
    pub subject_types: Vec<String>,
    /// Extra fields not defined in the schema.
    #[serde(flatten)]
    pub extra: std::collections::HashMap<String, serde_json::Value>,
}

#[derive(Debug, Clone, serde::Serialize, serde::Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct QueueCreateQueueOutput {
    pub queue: crate::api::tools::ozone::QueueDefsQueueView,
    /// Extra fields not defined in the schema.
    #[serde(flatten)]
    pub extra: std::collections::HashMap<String, serde_json::Value>,
}

/// QueueCreateQueue — Create a new moderation queue. Will fail if the queue configuration conflicts with an existing queue.
pub async fn queue_create_queue(
    client: &crate::xrpc::Client,
    input: &QueueCreateQueueInput,
) -> Result<QueueCreateQueueOutput, crate::xrpc::Error> {
    client
        .procedure("tools.ozone.queue.createQueue", input)
        .await
}