webhook_line/models/
account_link_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/// AccountLinkEvent : Event object for when a user has linked their LINE account with a provider's service account. You can reply to account link events.
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct AccountLinkEvent {
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    /// Reply token used to send reply message to this event. This property won't be included if linking the account has failed.
33    #[serde(rename = "replyToken", skip_serializing_if = "Option::is_none")]
34    pub reply_token: Option<String>,
35    #[serde(rename = "link")]
36    pub link: Box<models::LinkContent>,
37}
38
39impl AccountLinkEvent {
40    /// Event object for when a user has linked their LINE account with a provider's service account. You can reply to account link events.
41    pub fn new(
42        r#type: String,
43        timestamp: i64,
44        mode: models::EventMode,
45        webhook_event_id: String,
46        delivery_context: models::DeliveryContext,
47        link: models::LinkContent,
48    ) -> AccountLinkEvent {
49        AccountLinkEvent {
50            r#type: Some(r#type),
51            source: None,
52            timestamp,
53            mode,
54            webhook_event_id,
55            delivery_context: Box::new(delivery_context),
56            reply_token: None,
57            link: Box::new(link),
58        }
59    }
60}