1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct LdapSource {
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 = "server_uri")]
72 pub server_uri: String,
73 #[serde(
75 rename = "peer_certificate",
76 default,
77 with = "::serde_with::rust::double_option",
78 skip_serializing_if = "Option::is_none"
79 )]
80 pub peer_certificate: Option<Option<uuid::Uuid>>,
81 #[serde(
83 rename = "client_certificate",
84 default,
85 with = "::serde_with::rust::double_option",
86 skip_serializing_if = "Option::is_none"
87 )]
88 pub client_certificate: Option<Option<uuid::Uuid>>,
89 #[serde(rename = "bind_cn", skip_serializing_if = "Option::is_none")]
90 pub bind_cn: Option<String>,
91 #[serde(rename = "start_tls", skip_serializing_if = "Option::is_none")]
92 pub start_tls: Option<bool>,
93 #[serde(rename = "sni", skip_serializing_if = "Option::is_none")]
94 pub sni: Option<bool>,
95 #[serde(rename = "base_dn")]
96 pub base_dn: String,
97 #[serde(rename = "additional_user_dn", skip_serializing_if = "Option::is_none")]
99 pub additional_user_dn: Option<String>,
100 #[serde(rename = "additional_group_dn", skip_serializing_if = "Option::is_none")]
102 pub additional_group_dn: Option<String>,
103 #[serde(rename = "user_object_filter", skip_serializing_if = "Option::is_none")]
105 pub user_object_filter: Option<String>,
106 #[serde(rename = "group_object_filter", skip_serializing_if = "Option::is_none")]
108 pub group_object_filter: Option<String>,
109 #[serde(rename = "group_membership_field", skip_serializing_if = "Option::is_none")]
111 pub group_membership_field: Option<String>,
112 #[serde(rename = "user_membership_attribute", skip_serializing_if = "Option::is_none")]
114 pub user_membership_attribute: Option<String>,
115 #[serde(rename = "object_uniqueness_field", skip_serializing_if = "Option::is_none")]
117 pub object_uniqueness_field: Option<String>,
118 #[serde(
120 rename = "password_login_update_internal_password",
121 skip_serializing_if = "Option::is_none"
122 )]
123 pub password_login_update_internal_password: Option<bool>,
124 #[serde(rename = "sync_users", skip_serializing_if = "Option::is_none")]
125 pub sync_users: Option<bool>,
126 #[serde(rename = "sync_users_password", skip_serializing_if = "Option::is_none")]
128 pub sync_users_password: Option<bool>,
129 #[serde(rename = "sync_groups", skip_serializing_if = "Option::is_none")]
130 pub sync_groups: Option<bool>,
131 #[serde(
132 rename = "sync_parent_group",
133 default,
134 with = "::serde_with::rust::double_option",
135 skip_serializing_if = "Option::is_none"
136 )]
137 pub sync_parent_group: Option<Option<uuid::Uuid>>,
138 #[serde(rename = "connectivity", deserialize_with = "Option::deserialize")]
140 pub connectivity: Option<std::collections::HashMap<String, std::collections::HashMap<String, String>>>,
141 #[serde(rename = "lookup_groups_from_user", skip_serializing_if = "Option::is_none")]
143 pub lookup_groups_from_user: Option<bool>,
144 #[serde(rename = "delete_not_found_objects", skip_serializing_if = "Option::is_none")]
146 pub delete_not_found_objects: Option<bool>,
147}
148
149impl LdapSource {
150 pub fn new(
152 pk: uuid::Uuid,
153 name: String,
154 slug: String,
155 component: String,
156 verbose_name: String,
157 verbose_name_plural: String,
158 meta_model_name: String,
159 managed: Option<String>,
160 icon: String,
161 server_uri: String,
162 base_dn: String,
163 connectivity: Option<std::collections::HashMap<String, std::collections::HashMap<String, String>>>,
164 ) -> LdapSource {
165 LdapSource {
166 pk,
167 name,
168 slug,
169 enabled: None,
170 authentication_flow: None,
171 enrollment_flow: None,
172 user_property_mappings: None,
173 group_property_mappings: None,
174 component,
175 verbose_name,
176 verbose_name_plural,
177 meta_model_name,
178 policy_engine_mode: None,
179 user_matching_mode: None,
180 managed,
181 user_path_template: None,
182 icon,
183 server_uri,
184 peer_certificate: None,
185 client_certificate: None,
186 bind_cn: None,
187 start_tls: None,
188 sni: None,
189 base_dn,
190 additional_user_dn: None,
191 additional_group_dn: None,
192 user_object_filter: None,
193 group_object_filter: None,
194 group_membership_field: None,
195 user_membership_attribute: None,
196 object_uniqueness_field: None,
197 password_login_update_internal_password: None,
198 sync_users: None,
199 sync_users_password: None,
200 sync_groups: None,
201 sync_parent_group: None,
202 connectivity,
203 lookup_groups_from_user: None,
204 delete_not_found_objects: None,
205 }
206 }
207}