netbox_openapi/models/
writable_tunnel_request.rs

1/*
2 * NetBox REST API
3 *
4 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
5 *
6 * The version of the OpenAPI document: 4.4.2-Docker-3.4.1 (4.4)
7 *
8 * Generated by: https://openapi-generator.tech
9 */
10
11/// WritableTunnelRequest : Adds support for custom fields and tags.
12
13#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
14pub struct WritableTunnelRequest {
15    #[serde(rename = "name")]
16    pub name: String,
17    /// * `planned` - Planned * `active` - Active * `disabled` - Disabled
18    #[serde(rename = "status", skip_serializing_if = "Option::is_none")]
19    pub status: Option<Status>,
20    #[serde(
21        rename = "group",
22        default,
23        with = "::serde_with::rust::double_option",
24        skip_serializing_if = "Option::is_none"
25    )]
26    pub group: Option<Option<Box<crate::models::PatchedWritableTunnelRequestGroup>>>,
27    /// * `ipsec-transport` - IPsec - Transport * `ipsec-tunnel` - IPsec - Tunnel * `ip-ip` - IP-in-IP * `gre` - GRE * `wireguard` - WireGuard * `openvpn` - OpenVPN * `l2tp` - L2TP * `pptp` - PPTP
28    #[serde(rename = "encapsulation")]
29    pub encapsulation: Encapsulation,
30    #[serde(
31        rename = "ipsec_profile",
32        default,
33        with = "::serde_with::rust::double_option",
34        skip_serializing_if = "Option::is_none"
35    )]
36    pub ipsec_profile: Option<Option<Box<crate::models::PatchedWritableTunnelRequestIpsecProfile>>>,
37    #[serde(
38        rename = "tenant",
39        default,
40        with = "::serde_with::rust::double_option",
41        skip_serializing_if = "Option::is_none"
42    )]
43    pub tenant: Option<Option<Box<crate::models::AsnRangeRequestTenant>>>,
44    #[serde(
45        rename = "tunnel_id",
46        default,
47        with = "::serde_with::rust::double_option",
48        skip_serializing_if = "Option::is_none"
49    )]
50    pub tunnel_id: Option<Option<i64>>,
51    #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
52    pub description: Option<String>,
53    #[serde(rename = "comments", skip_serializing_if = "Option::is_none")]
54    pub comments: Option<String>,
55    #[serde(rename = "tags", skip_serializing_if = "Option::is_none")]
56    pub tags: Option<Vec<crate::models::NestedTagRequest>>,
57    #[serde(rename = "custom_fields", skip_serializing_if = "Option::is_none")]
58    pub custom_fields: Option<::std::collections::HashMap<String, serde_json::Value>>,
59}
60
61impl WritableTunnelRequest {
62    /// Adds support for custom fields and tags.
63    pub fn new(name: String, encapsulation: Encapsulation) -> WritableTunnelRequest {
64        WritableTunnelRequest {
65            name,
66            status: None,
67            group: None,
68            encapsulation,
69            ipsec_profile: None,
70            tenant: None,
71            tunnel_id: None,
72            description: None,
73            comments: None,
74            tags: None,
75            custom_fields: None,
76        }
77    }
78}
79
80/// * `planned` - Planned * `active` - Active * `disabled` - Disabled
81#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
82pub enum Status {
83    #[serde(rename = "planned")]
84    Planned,
85    #[serde(rename = "active")]
86    Active,
87    #[serde(rename = "disabled")]
88    Disabled,
89}
90
91impl Default for Status {
92    fn default() -> Status {
93        Self::Planned
94    }
95}
96/// * `ipsec-transport` - IPsec - Transport * `ipsec-tunnel` - IPsec - Tunnel * `ip-ip` - IP-in-IP * `gre` - GRE * `wireguard` - WireGuard * `openvpn` - OpenVPN * `l2tp` - L2TP * `pptp` - PPTP
97#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
98pub enum Encapsulation {
99    #[serde(rename = "ipsec-transport")]
100    IpsecTransport,
101    #[serde(rename = "ipsec-tunnel")]
102    IpsecTunnel,
103    #[serde(rename = "ip-ip")]
104    IpIp,
105    #[serde(rename = "gre")]
106    Gre,
107    #[serde(rename = "wireguard")]
108    Wireguard,
109    #[serde(rename = "openvpn")]
110    Openvpn,
111    #[serde(rename = "l2tp")]
112    L2tp,
113    #[serde(rename = "pptp")]
114    Pptp,
115}
116
117impl Default for Encapsulation {
118    fn default() -> Encapsulation {
119        Self::IpsecTransport
120    }
121}