1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct SamlSource {
17 #[serde(rename = "pk")]
18 pub pk: uuid::Uuid,
19 #[serde(rename = "name")]
21 pub name: String,
22 #[serde(rename = "slug")]
24 pub slug: String,
25 #[serde(rename = "enabled", skip_serializing_if = "Option::is_none")]
26 pub enabled: Option<bool>,
27 #[serde(
29 rename = "authentication_flow",
30 default,
31 with = "::serde_with::rust::double_option",
32 skip_serializing_if = "Option::is_none"
33 )]
34 pub authentication_flow: Option<Option<uuid::Uuid>>,
35 #[serde(
37 rename = "enrollment_flow",
38 default,
39 with = "::serde_with::rust::double_option",
40 skip_serializing_if = "Option::is_none"
41 )]
42 pub enrollment_flow: Option<Option<uuid::Uuid>>,
43 #[serde(rename = "user_property_mappings", skip_serializing_if = "Option::is_none")]
44 pub user_property_mappings: Option<Vec<uuid::Uuid>>,
45 #[serde(rename = "group_property_mappings", skip_serializing_if = "Option::is_none")]
46 pub group_property_mappings: Option<Vec<uuid::Uuid>>,
47 #[serde(rename = "component")]
49 pub component: String,
50 #[serde(rename = "verbose_name")]
52 pub verbose_name: String,
53 #[serde(rename = "verbose_name_plural")]
55 pub verbose_name_plural: String,
56 #[serde(rename = "meta_model_name")]
58 pub meta_model_name: String,
59 #[serde(rename = "policy_engine_mode", skip_serializing_if = "Option::is_none")]
60 pub policy_engine_mode: Option<models::PolicyEngineMode>,
61 #[serde(rename = "user_matching_mode", skip_serializing_if = "Option::is_none")]
63 pub user_matching_mode: Option<models::UserMatchingModeEnum>,
64 #[serde(rename = "managed", deserialize_with = "Option::deserialize")]
66 pub managed: Option<String>,
67 #[serde(rename = "user_path_template", skip_serializing_if = "Option::is_none")]
68 pub user_path_template: Option<String>,
69 #[serde(rename = "icon")]
70 pub icon: String,
71 #[serde(rename = "group_matching_mode", skip_serializing_if = "Option::is_none")]
73 pub group_matching_mode: Option<models::GroupMatchingModeEnum>,
74 #[serde(rename = "pre_authentication_flow")]
76 pub pre_authentication_flow: uuid::Uuid,
77 #[serde(rename = "issuer", skip_serializing_if = "Option::is_none")]
79 pub issuer: Option<String>,
80 #[serde(rename = "sso_url")]
82 pub sso_url: String,
83 #[serde(
85 rename = "slo_url",
86 default,
87 with = "::serde_with::rust::double_option",
88 skip_serializing_if = "Option::is_none"
89 )]
90 pub slo_url: Option<Option<String>>,
91 #[serde(rename = "allow_idp_initiated", skip_serializing_if = "Option::is_none")]
93 pub allow_idp_initiated: Option<bool>,
94 #[serde(rename = "name_id_policy", skip_serializing_if = "Option::is_none")]
96 pub name_id_policy: Option<models::SamlNameIdPolicyEnum>,
97 #[serde(rename = "binding_type", skip_serializing_if = "Option::is_none")]
98 pub binding_type: Option<models::BindingTypeEnum>,
99 #[serde(
101 rename = "verification_kp",
102 default,
103 with = "::serde_with::rust::double_option",
104 skip_serializing_if = "Option::is_none"
105 )]
106 pub verification_kp: Option<Option<uuid::Uuid>>,
107 #[serde(
109 rename = "signing_kp",
110 default,
111 with = "::serde_with::rust::double_option",
112 skip_serializing_if = "Option::is_none"
113 )]
114 pub signing_kp: Option<Option<uuid::Uuid>>,
115 #[serde(rename = "digest_algorithm", skip_serializing_if = "Option::is_none")]
116 pub digest_algorithm: Option<models::DigestAlgorithmEnum>,
117 #[serde(rename = "signature_algorithm", skip_serializing_if = "Option::is_none")]
118 pub signature_algorithm: Option<models::SignatureAlgorithmEnum>,
119 #[serde(rename = "temporary_user_delete_after", skip_serializing_if = "Option::is_none")]
121 pub temporary_user_delete_after: Option<String>,
122 #[serde(
124 rename = "encryption_kp",
125 default,
126 with = "::serde_with::rust::double_option",
127 skip_serializing_if = "Option::is_none"
128 )]
129 pub encryption_kp: Option<Option<uuid::Uuid>>,
130}
131
132impl SamlSource {
133 pub fn new(
135 pk: uuid::Uuid,
136 name: String,
137 slug: String,
138 component: String,
139 verbose_name: String,
140 verbose_name_plural: String,
141 meta_model_name: String,
142 managed: Option<String>,
143 icon: String,
144 pre_authentication_flow: uuid::Uuid,
145 sso_url: String,
146 ) -> SamlSource {
147 SamlSource {
148 pk,
149 name,
150 slug,
151 enabled: None,
152 authentication_flow: None,
153 enrollment_flow: None,
154 user_property_mappings: None,
155 group_property_mappings: None,
156 component,
157 verbose_name,
158 verbose_name_plural,
159 meta_model_name,
160 policy_engine_mode: None,
161 user_matching_mode: None,
162 managed,
163 user_path_template: None,
164 icon,
165 group_matching_mode: None,
166 pre_authentication_flow,
167 issuer: None,
168 sso_url,
169 slo_url: None,
170 allow_idp_initiated: None,
171 name_id_policy: None,
172 binding_type: None,
173 verification_kp: None,
174 signing_kp: None,
175 digest_algorithm: None,
176 signature_algorithm: None,
177 temporary_user_delete_after: None,
178 encryption_kp: None,
179 }
180 }
181}