webhook_line/models/
leave_event.rs

1/*
2 * Webhook Type Definition
3 *
4 * Webhook event definition of the LINE Messaging API
5 *
6 * The version of the OpenAPI document: 1.0.0
7 *
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// LeaveEvent : Event object for when a user removes your LINE Official Account from a group chat or when your LINE Official Account leaves a group chat or multi-person chat.
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct LeaveEvent {
17    /// Type of the event
18    #[serde(rename = "type", skip_serializing_if = "Option::is_none")]
19    pub r#type: Option<String>,
20    #[serde(rename = "source", skip_serializing_if = "Option::is_none")]
21    pub source: Option<Box<models::Source>>,
22    /// Time of the event in milliseconds.
23    #[serde(rename = "timestamp")]
24    pub timestamp: i64,
25    #[serde(rename = "mode")]
26    pub mode: models::EventMode,
27    /// Webhook Event ID. An ID that uniquely identifies a webhook event. This is a string in ULID format.
28    #[serde(rename = "webhookEventId")]
29    pub webhook_event_id: String,
30    #[serde(rename = "deliveryContext")]
31    pub delivery_context: Box<models::DeliveryContext>,
32}
33
34impl LeaveEvent {
35    /// Event object for when a user removes your LINE Official Account from a group chat or when your LINE Official Account leaves a group chat or multi-person chat.
36    pub fn new(
37        r#type: String,
38        timestamp: i64,
39        mode: models::EventMode,
40        webhook_event_id: String,
41        delivery_context: models::DeliveryContext,
42    ) -> LeaveEvent {
43        LeaveEvent {
44            r#type: Some(r#type),
45            source: None,
46            timestamp,
47            mode,
48            webhook_event_id,
49            delivery_context: Box::new(delivery_context),
50        }
51    }
52}