zernio 0.0.132

API reference for Zernio. Authenticate with a Bearer API key. Base URL: https://zernio.com/api
Documentation
/*
 * Zernio API
 *
 * API reference for Zernio. Authenticate with a Bearer API key. Base URL: https://zernio.com/api
 *
 * The version of the OpenAPI document: 1.0.1
 * Contact: support@zernio.com
 * Generated by: https://openapi-generator.tech
 */

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

/// WebhookPayloadMessageEdited : Webhook payload for `message.edited` events. Fires when the sender edits a previously-sent message. Supported platforms: Instagram, Facebook Messenger, Telegram. The `message` object reflects the LATEST state; `editHistory` contains every prior version in order (oldest first), so the last entry is the version immediately before the current content.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct WebhookPayloadMessageEdited {
    #[serde(rename = "id")]
    pub id: String,
    #[serde(rename = "event")]
    pub event: Event,
    #[serde(rename = "message")]
    pub message: Box<models::InboxWebhookMessage>,
    /// Prior versions of the message, oldest first.
    #[serde(rename = "editHistory")]
    pub edit_history: Vec<models::WebhookPayloadMessageEditedEditHistoryInner>,
    /// Total number of edits applied to this message.
    #[serde(rename = "editCount")]
    pub edit_count: i32,
    /// When the most recent edit happened.
    #[serde(rename = "editedAt")]
    pub edited_at: String,
    #[serde(rename = "conversation")]
    pub conversation: Box<models::InboxWebhookConversation>,
    #[serde(rename = "account")]
    pub account: Box<models::InboxWebhookAccount>,
    #[serde(rename = "timestamp")]
    pub timestamp: String,
}

impl WebhookPayloadMessageEdited {
    /// Webhook payload for `message.edited` events. Fires when the sender edits a previously-sent message. Supported platforms: Instagram, Facebook Messenger, Telegram. The `message` object reflects the LATEST state; `editHistory` contains every prior version in order (oldest first), so the last entry is the version immediately before the current content.
    pub fn new(
        id: String,
        event: Event,
        message: models::InboxWebhookMessage,
        edit_history: Vec<models::WebhookPayloadMessageEditedEditHistoryInner>,
        edit_count: i32,
        edited_at: String,
        conversation: models::InboxWebhookConversation,
        account: models::InboxWebhookAccount,
        timestamp: String,
    ) -> WebhookPayloadMessageEdited {
        WebhookPayloadMessageEdited {
            id,
            event,
            message: Box::new(message),
            edit_history,
            edit_count,
            edited_at,
            conversation: Box::new(conversation),
            account: Box::new(account),
            timestamp,
        }
    }
}
///
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Event {
    #[serde(rename = "message.edited")]
    MessageEdited,
}

impl Default for Event {
    fn default() -> Event {
        Self::MessageEdited
    }
}