netbox_openapi/models/
ip_sec_profile.rs1#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
14pub struct IpSecProfile {
15 #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
16 pub id: Option<i32>,
17 #[serde(rename = "url", skip_serializing_if = "Option::is_none")]
18 pub url: Option<String>,
19 #[serde(rename = "display_url", skip_serializing_if = "Option::is_none")]
20 pub display_url: Option<String>,
21 #[serde(rename = "display", skip_serializing_if = "Option::is_none")]
22 pub display: Option<String>,
23 #[serde(rename = "name")]
24 pub name: String,
25 #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
26 pub description: Option<String>,
27 #[serde(rename = "mode")]
28 pub mode: Box<crate::models::IpSecProfileMode>,
29 #[serde(rename = "ike_policy")]
30 pub ike_policy: Box<crate::models::BriefIkePolicy>,
31 #[serde(rename = "ipsec_policy")]
32 pub ipsec_policy: Box<crate::models::BriefIpSecPolicy>,
33 #[serde(rename = "comments", skip_serializing_if = "Option::is_none")]
34 pub comments: Option<String>,
35 #[serde(rename = "tags", skip_serializing_if = "Option::is_none")]
36 pub tags: Option<Vec<crate::models::NestedTag>>,
37 #[serde(rename = "custom_fields", skip_serializing_if = "Option::is_none")]
38 pub custom_fields: Option<::std::collections::HashMap<String, serde_json::Value>>,
39 #[serde(
40 rename = "created",
41 default,
42 with = "::serde_with::rust::double_option",
43 skip_serializing_if = "Option::is_none"
44 )]
45 pub created: Option<Option<String>>,
46 #[serde(
47 rename = "last_updated",
48 default,
49 with = "::serde_with::rust::double_option",
50 skip_serializing_if = "Option::is_none"
51 )]
52 pub last_updated: Option<Option<String>>,
53}
54
55impl IpSecProfile {
56 pub fn new(
58 name: String,
59 mode: crate::models::IpSecProfileMode,
60 ike_policy: crate::models::BriefIkePolicy,
61 ipsec_policy: crate::models::BriefIpSecPolicy,
62 ) -> IpSecProfile {
63 IpSecProfile {
64 id: None,
65 url: None,
66 display_url: None,
67 display: None,
68 name,
69 description: None,
70 mode: Box::new(mode),
71 ike_policy: Box::new(ike_policy),
72 ipsec_policy: Box::new(ipsec_policy),
73 comments: None,
74 tags: None,
75 custom_fields: None,
76 created: None,
77 last_updated: None,
78 }
79 }
80}