line-bot-sdk-rust 3.0.0

LINE Messaging API SDK for Rust
Documentation
/*
* Copyright (C) 2016 LINE Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

/*
 * Webhook Type Definition
 *
 * Webhook event definition of the LINE Messaging API
 *
 * The version of the OpenAPI document: 1.0.0
 *
 * Generated by: https://openapi-generator.tech
 */

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

/// MemberJoinedEvent : Event object for when a user joins a group chat or multi-person chat that the LINE Official Account is in.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct MemberJoinedEvent {
    #[serde(rename = "source", skip_serializing_if = "Option::is_none")]
    pub source: Option<Box<models::Source>>,
    /// Time of the event in milliseconds.
    #[serde(rename = "timestamp")]
    pub timestamp: i64,
    #[serde(rename = "mode")]
    pub mode: models::EventMode,
    /// Webhook Event ID. An ID that uniquely identifies a webhook event. This is a string in ULID format.
    #[serde(rename = "webhookEventId")]
    pub webhook_event_id: String,
    #[serde(rename = "deliveryContext")]
    pub delivery_context: Box<models::DeliveryContext>,
    /// Reply token used to send reply message to this event
    #[serde(rename = "replyToken")]
    pub reply_token: String,
    #[serde(rename = "joined")]
    pub joined: Box<models::JoinedMembers>,
}

impl MemberJoinedEvent {
    /// Event object for when a user joins a group chat or multi-person chat that the LINE Official Account is in.
    pub fn new(
        timestamp: i64,
        mode: models::EventMode,
        webhook_event_id: String,
        delivery_context: models::DeliveryContext,
        reply_token: String,
        joined: models::JoinedMembers,
    ) -> MemberJoinedEvent {
        MemberJoinedEvent {
            source: None,
            timestamp,
            mode,
            webhook_event_id,
            delivery_context: Box::new(delivery_context),
            reply_token,
            joined: Box::new(joined),
        }
    }
}