spatio-sdk 0.0.2

Rust SDK for the SpatioAPI. Generated from the official OpenAPI spec.
Documentation
/*
 * SpatioAPI
 *
 * The REST API that owns every resource in your Spatio workspace: notes, sheets, slides, tasks, calendar events, mail, chat, files, and contacts. SpatioMCP wraps this API; Spatio Desktop reads from it. You can call it directly from your own code.  All requests must be authenticated with a Personal Access Token (`Authorization: Bearer pat_...`) or an OAuth 2.1 access token, and use HTTPS.  Official SDKs (MIT, generated from this spec on every release):  - TypeScript: https://github.com/spatio-labs/spatio-ts (`npm install @spatio-labs/spatio-ts`) - Python: https://github.com/spatio-labs/spatio-py (`pip install spatio-sdk`) - Go: https://github.com/spatio-labs/spatio-go (`go get github.com/spatio-labs/spatio-go`)  This specification is generated from the platform-service Go source on every push to `main`. The spec, not hand-written documentation, is the source of truth: server stubs and SDKs are generated from it, and any drift between the spec and the running service fails CI. 
 *
 * The version of the OpenAPI document: v1
 * Contact: hello@spatio.app
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct CreateEventRequest {
    #[serde(rename = "account_id")]
    pub account_id: String,
    /// Specific calendar within the account; omit for the default.
    #[serde(rename = "calendar_id", skip_serializing_if = "Option::is_none")]
    pub calendar_id: Option<String>,
    #[serde(rename = "event")]
    pub event: Box<models::SpatioEvent>,
    /// Notification policy passed through to the provider.
    #[serde(rename = "send_updates", skip_serializing_if = "Option::is_none")]
    pub send_updates: Option<SendUpdates>,
    /// When set, the platform will auto-attach a conference link of the matching type (`spatio`, `meet`, `zoom`, `teams`). 
    #[serde(rename = "conference_type", skip_serializing_if = "Option::is_none")]
    pub conference_type: Option<String>,
}

impl CreateEventRequest {
    pub fn new(account_id: String, event: models::SpatioEvent) -> CreateEventRequest {
        CreateEventRequest {
            account_id,
            calendar_id: None,
            event: Box::new(event),
            send_updates: None,
            conference_type: None,
        }
    }
}
/// Notification policy passed through to the provider.
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum SendUpdates {
    #[serde(rename = "all")]
    All,
    #[serde(rename = "externalOnly")]
    ExternalOnly,
    #[serde(rename = "none")]
    None,
}

impl Default for SendUpdates {
    fn default() -> SendUpdates {
        Self::All
    }
}