netbox_openapi/models/
writable_ike_proposal_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/// WritableIkeProposalRequest : Adds support for custom fields and tags.
12
13#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
14pub struct WritableIkeProposalRequest {
15    #[serde(rename = "name")]
16    pub name: String,
17    #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
18    pub description: Option<String>,
19    /// * `preshared-keys` - Pre-shared keys * `certificates` - Certificates * `rsa-signatures` - RSA signatures * `dsa-signatures` - DSA signatures
20    #[serde(rename = "authentication_method")]
21    pub authentication_method: AuthenticationMethod,
22    /// * `aes-128-cbc` - 128-bit AES (CBC) * `aes-128-gcm` - 128-bit AES (GCM) * `aes-192-cbc` - 192-bit AES (CBC) * `aes-192-gcm` - 192-bit AES (GCM) * `aes-256-cbc` - 256-bit AES (CBC) * `aes-256-gcm` - 256-bit AES (GCM) * `3des-cbc` - 3DES * `des-cbc` - DES
23    #[serde(rename = "encryption_algorithm")]
24    pub encryption_algorithm: EncryptionAlgorithm,
25    /// * `hmac-sha1` - SHA-1 HMAC * `hmac-sha256` - SHA-256 HMAC * `hmac-sha384` - SHA-384 HMAC * `hmac-sha512` - SHA-512 HMAC * `hmac-md5` - MD5 HMAC
26    #[serde(
27        rename = "authentication_algorithm",
28        default,
29        with = "::serde_with::rust::double_option",
30        skip_serializing_if = "Option::is_none"
31    )]
32    pub authentication_algorithm: Option<Option<AuthenticationAlgorithm>>,
33    /// Diffie-Hellman group ID  * `1` - Group 1 * `2` - Group 2 * `5` - Group 5 * `14` - Group 14 * `15` - Group 15 * `16` - Group 16 * `17` - Group 17 * `18` - Group 18 * `19` - Group 19 * `20` - Group 20 * `21` - Group 21 * `22` - Group 22 * `23` - Group 23 * `24` - Group 24 * `25` - Group 25 * `26` - Group 26 * `27` - Group 27 * `28` - Group 28 * `29` - Group 29 * `30` - Group 30 * `31` - Group 31 * `32` - Group 32 * `33` - Group 33 * `34` - Group 34
34    #[serde(rename = "group")]
35    pub group: Group,
36    /// Security association lifetime (in seconds)
37    #[serde(
38        rename = "sa_lifetime",
39        default,
40        with = "::serde_with::rust::double_option",
41        skip_serializing_if = "Option::is_none"
42    )]
43    pub sa_lifetime: Option<Option<i32>>,
44    #[serde(rename = "comments", skip_serializing_if = "Option::is_none")]
45    pub comments: Option<String>,
46    #[serde(rename = "tags", skip_serializing_if = "Option::is_none")]
47    pub tags: Option<Vec<crate::models::NestedTagRequest>>,
48    #[serde(rename = "custom_fields", skip_serializing_if = "Option::is_none")]
49    pub custom_fields: Option<::std::collections::HashMap<String, serde_json::Value>>,
50}
51
52impl WritableIkeProposalRequest {
53    /// Adds support for custom fields and tags.
54    pub fn new(
55        name: String,
56        authentication_method: AuthenticationMethod,
57        encryption_algorithm: EncryptionAlgorithm,
58        group: Group,
59    ) -> WritableIkeProposalRequest {
60        WritableIkeProposalRequest {
61            name,
62            description: None,
63            authentication_method,
64            encryption_algorithm,
65            authentication_algorithm: None,
66            group,
67            sa_lifetime: None,
68            comments: None,
69            tags: None,
70            custom_fields: None,
71        }
72    }
73}
74
75/// * `preshared-keys` - Pre-shared keys * `certificates` - Certificates * `rsa-signatures` - RSA signatures * `dsa-signatures` - DSA signatures
76#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
77pub enum AuthenticationMethod {
78    #[serde(rename = "preshared-keys")]
79    PresharedKeys,
80    #[serde(rename = "certificates")]
81    Certificates,
82    #[serde(rename = "rsa-signatures")]
83    RsaSignatures,
84    #[serde(rename = "dsa-signatures")]
85    DsaSignatures,
86}
87
88impl Default for AuthenticationMethod {
89    fn default() -> AuthenticationMethod {
90        Self::PresharedKeys
91    }
92}
93/// * `aes-128-cbc` - 128-bit AES (CBC) * `aes-128-gcm` - 128-bit AES (GCM) * `aes-192-cbc` - 192-bit AES (CBC) * `aes-192-gcm` - 192-bit AES (GCM) * `aes-256-cbc` - 256-bit AES (CBC) * `aes-256-gcm` - 256-bit AES (GCM) * `3des-cbc` - 3DES * `des-cbc` - DES
94#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
95pub enum EncryptionAlgorithm {
96    #[serde(rename = "aes-128-cbc")]
97    Aes128Cbc,
98    #[serde(rename = "aes-128-gcm")]
99    Aes128Gcm,
100    #[serde(rename = "aes-192-cbc")]
101    Aes192Cbc,
102    #[serde(rename = "aes-192-gcm")]
103    Aes192Gcm,
104    #[serde(rename = "aes-256-cbc")]
105    Aes256Cbc,
106    #[serde(rename = "aes-256-gcm")]
107    Aes256Gcm,
108    #[serde(rename = "3des-cbc")]
109    Variant3desCbc,
110    #[serde(rename = "des-cbc")]
111    DesCbc,
112}
113
114impl Default for EncryptionAlgorithm {
115    fn default() -> EncryptionAlgorithm {
116        Self::Aes128Cbc
117    }
118}
119/// * `hmac-sha1` - SHA-1 HMAC * `hmac-sha256` - SHA-256 HMAC * `hmac-sha384` - SHA-384 HMAC * `hmac-sha512` - SHA-512 HMAC * `hmac-md5` - MD5 HMAC
120#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
121pub enum AuthenticationAlgorithm {
122    #[serde(rename = "hmac-sha1")]
123    HmacSha1,
124    #[serde(rename = "hmac-sha256")]
125    HmacSha256,
126    #[serde(rename = "hmac-sha384")]
127    HmacSha384,
128    #[serde(rename = "hmac-sha512")]
129    HmacSha512,
130    #[serde(rename = "hmac-md5")]
131    HmacMd5,
132    #[serde(rename = "")]
133    Empty,
134    #[serde(rename = "null")]
135    Null,
136}
137
138impl Default for AuthenticationAlgorithm {
139    fn default() -> AuthenticationAlgorithm {
140        Self::HmacSha1
141    }
142}
143/// Diffie-Hellman group ID  * `1` - Group 1 * `2` - Group 2 * `5` - Group 5 * `14` - Group 14 * `15` - Group 15 * `16` - Group 16 * `17` - Group 17 * `18` - Group 18 * `19` - Group 19 * `20` - Group 20 * `21` - Group 21 * `22` - Group 22 * `23` - Group 23 * `24` - Group 24 * `25` - Group 25 * `26` - Group 26 * `27` - Group 27 * `28` - Group 28 * `29` - Group 29 * `30` - Group 30 * `31` - Group 31 * `32` - Group 32 * `33` - Group 33 * `34` - Group 34
144#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
145pub enum Group {
146    #[serde(rename = "1")]
147    Variant1,
148    #[serde(rename = "2")]
149    Variant2,
150    #[serde(rename = "5")]
151    Variant5,
152    #[serde(rename = "14")]
153    Variant14,
154    #[serde(rename = "15")]
155    Variant15,
156    #[serde(rename = "16")]
157    Variant16,
158    #[serde(rename = "17")]
159    Variant17,
160    #[serde(rename = "18")]
161    Variant18,
162    #[serde(rename = "19")]
163    Variant19,
164    #[serde(rename = "20")]
165    Variant20,
166    #[serde(rename = "21")]
167    Variant21,
168    #[serde(rename = "22")]
169    Variant22,
170    #[serde(rename = "23")]
171    Variant23,
172    #[serde(rename = "24")]
173    Variant24,
174    #[serde(rename = "25")]
175    Variant25,
176    #[serde(rename = "26")]
177    Variant26,
178    #[serde(rename = "27")]
179    Variant27,
180    #[serde(rename = "28")]
181    Variant28,
182    #[serde(rename = "29")]
183    Variant29,
184    #[serde(rename = "30")]
185    Variant30,
186    #[serde(rename = "31")]
187    Variant31,
188    #[serde(rename = "32")]
189    Variant32,
190    #[serde(rename = "33")]
191    Variant33,
192    #[serde(rename = "34")]
193    Variant34,
194}
195
196impl Default for Group {
197    fn default() -> Group {
198        Self::Variant1
199    }
200}