use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct LdapSource {
#[serde(rename = "pk")]
pub pk: uuid::Uuid,
#[serde(rename = "name")]
pub name: String,
#[serde(rename = "slug")]
pub slug: String,
#[serde(rename = "enabled", skip_serializing_if = "Option::is_none")]
pub enabled: Option<bool>,
#[serde(rename = "promoted", skip_serializing_if = "Option::is_none")]
pub promoted: Option<bool>,
#[serde(
rename = "authentication_flow",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub authentication_flow: Option<Option<uuid::Uuid>>,
#[serde(
rename = "enrollment_flow",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub enrollment_flow: Option<Option<uuid::Uuid>>,
#[serde(rename = "user_property_mappings", skip_serializing_if = "Option::is_none")]
pub user_property_mappings: Option<Vec<uuid::Uuid>>,
#[serde(rename = "group_property_mappings", skip_serializing_if = "Option::is_none")]
pub group_property_mappings: Option<Vec<uuid::Uuid>>,
#[serde(rename = "component")]
pub component: String,
#[serde(rename = "verbose_name")]
pub verbose_name: String,
#[serde(rename = "verbose_name_plural")]
pub verbose_name_plural: String,
#[serde(rename = "meta_model_name")]
pub meta_model_name: String,
#[serde(rename = "policy_engine_mode", skip_serializing_if = "Option::is_none")]
pub policy_engine_mode: Option<models::PolicyEngineMode>,
#[serde(rename = "user_matching_mode", skip_serializing_if = "Option::is_none")]
pub user_matching_mode: Option<models::UserMatchingModeEnum>,
#[serde(rename = "managed", deserialize_with = "Option::deserialize")]
pub managed: Option<String>,
#[serde(rename = "user_path_template", skip_serializing_if = "Option::is_none")]
pub user_path_template: Option<String>,
#[serde(rename = "icon", skip_serializing_if = "Option::is_none")]
pub icon: Option<String>,
#[serde(rename = "icon_url")]
pub icon_url: String,
#[serde(rename = "icon_themed_urls", deserialize_with = "Option::deserialize")]
pub icon_themed_urls: Option<models::ThemedUrls>,
#[serde(rename = "server_uri")]
pub server_uri: String,
#[serde(
rename = "peer_certificate",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub peer_certificate: Option<Option<uuid::Uuid>>,
#[serde(
rename = "client_certificate",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub client_certificate: Option<Option<uuid::Uuid>>,
#[serde(rename = "bind_cn", skip_serializing_if = "Option::is_none")]
pub bind_cn: Option<String>,
#[serde(rename = "start_tls", skip_serializing_if = "Option::is_none")]
pub start_tls: Option<bool>,
#[serde(rename = "sni", skip_serializing_if = "Option::is_none")]
pub sni: Option<bool>,
#[serde(rename = "base_dn")]
pub base_dn: String,
#[serde(rename = "additional_user_dn", skip_serializing_if = "Option::is_none")]
pub additional_user_dn: Option<String>,
#[serde(rename = "additional_group_dn", skip_serializing_if = "Option::is_none")]
pub additional_group_dn: Option<String>,
#[serde(rename = "user_object_filter", skip_serializing_if = "Option::is_none")]
pub user_object_filter: Option<String>,
#[serde(rename = "group_object_filter", skip_serializing_if = "Option::is_none")]
pub group_object_filter: Option<String>,
#[serde(rename = "group_membership_field", skip_serializing_if = "Option::is_none")]
pub group_membership_field: Option<String>,
#[serde(rename = "user_membership_attribute", skip_serializing_if = "Option::is_none")]
pub user_membership_attribute: Option<String>,
#[serde(rename = "object_uniqueness_field", skip_serializing_if = "Option::is_none")]
pub object_uniqueness_field: Option<String>,
#[serde(
rename = "password_login_update_internal_password",
skip_serializing_if = "Option::is_none"
)]
pub password_login_update_internal_password: Option<bool>,
#[serde(rename = "sync_users", skip_serializing_if = "Option::is_none")]
pub sync_users: Option<bool>,
#[serde(rename = "sync_users_password", skip_serializing_if = "Option::is_none")]
pub sync_users_password: Option<bool>,
#[serde(rename = "sync_groups", skip_serializing_if = "Option::is_none")]
pub sync_groups: Option<bool>,
#[serde(
rename = "sync_parent_group",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub sync_parent_group: Option<Option<uuid::Uuid>>,
#[serde(rename = "connectivity", deserialize_with = "Option::deserialize")]
pub connectivity: Option<std::collections::HashMap<String, std::collections::HashMap<String, String>>>,
#[serde(rename = "lookup_groups_from_user", skip_serializing_if = "Option::is_none")]
pub lookup_groups_from_user: Option<bool>,
#[serde(rename = "delete_not_found_objects", skip_serializing_if = "Option::is_none")]
pub delete_not_found_objects: Option<bool>,
#[serde(rename = "sync_outgoing_trigger_mode", skip_serializing_if = "Option::is_none")]
pub sync_outgoing_trigger_mode: Option<models::SyncOutgoingTriggerModeEnum>,
}
impl LdapSource {
pub fn new(
pk: uuid::Uuid,
name: String,
slug: String,
component: String,
verbose_name: String,
verbose_name_plural: String,
meta_model_name: String,
managed: Option<String>,
icon_url: String,
icon_themed_urls: Option<models::ThemedUrls>,
server_uri: String,
base_dn: String,
connectivity: Option<std::collections::HashMap<String, std::collections::HashMap<String, String>>>,
) -> LdapSource {
LdapSource {
pk,
name,
slug,
enabled: None,
promoted: None,
authentication_flow: None,
enrollment_flow: None,
user_property_mappings: None,
group_property_mappings: None,
component,
verbose_name,
verbose_name_plural,
meta_model_name,
policy_engine_mode: None,
user_matching_mode: None,
managed,
user_path_template: None,
icon: None,
icon_url,
icon_themed_urls,
server_uri,
peer_certificate: None,
client_certificate: None,
bind_cn: None,
start_tls: None,
sni: None,
base_dn,
additional_user_dn: None,
additional_group_dn: None,
user_object_filter: None,
group_object_filter: None,
group_membership_field: None,
user_membership_attribute: None,
object_uniqueness_field: None,
password_login_update_internal_password: None,
sync_users: None,
sync_users_password: None,
sync_groups: None,
sync_parent_group: None,
connectivity,
lookup_groups_from_user: None,
delete_not_found_objects: None,
sync_outgoing_trigger_mode: None,
}
}
}