use crate::models;
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct LdapProvider {
#[serde(rename = "pk")]
pub pk: i32,
#[serde(rename = "name")]
pub name: String,
#[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 = "authorization_flow")]
pub authorization_flow: uuid::Uuid,
#[serde(rename = "property_mappings", skip_serializing_if = "Option::is_none")]
pub property_mappings: Option<Vec<uuid::Uuid>>,
#[serde(rename = "component")]
pub component: String,
#[serde(rename = "assigned_application_slug")]
pub assigned_application_slug: String,
#[serde(rename = "assigned_application_name")]
pub assigned_application_name: String,
#[serde(rename = "assigned_backchannel_application_slug")]
pub assigned_backchannel_application_slug: String,
#[serde(rename = "assigned_backchannel_application_name")]
pub assigned_backchannel_application_name: 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 = "base_dn", skip_serializing_if = "Option::is_none")]
pub base_dn: Option<String>,
#[serde(rename = "search_group", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub search_group: Option<Option<uuid::Uuid>>,
#[serde(rename = "certificate", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub certificate: Option<Option<uuid::Uuid>>,
#[serde(rename = "tls_server_name", skip_serializing_if = "Option::is_none")]
pub tls_server_name: Option<String>,
#[serde(rename = "uid_start_number", skip_serializing_if = "Option::is_none")]
pub uid_start_number: Option<i32>,
#[serde(rename = "gid_start_number", skip_serializing_if = "Option::is_none")]
pub gid_start_number: Option<i32>,
#[serde(rename = "outpost_set")]
pub outpost_set: Vec<String>,
#[serde(rename = "search_mode", skip_serializing_if = "Option::is_none")]
pub search_mode: Option<models::LdapapiAccessMode>,
#[serde(rename = "bind_mode", skip_serializing_if = "Option::is_none")]
pub bind_mode: Option<models::LdapapiAccessMode>,
#[serde(rename = "mfa_support", skip_serializing_if = "Option::is_none")]
pub mfa_support: Option<bool>,
}
impl LdapProvider {
pub fn new(pk: i32, name: String, authorization_flow: uuid::Uuid, component: String, assigned_application_slug: String, assigned_application_name: String, assigned_backchannel_application_slug: String, assigned_backchannel_application_name: String, verbose_name: String, verbose_name_plural: String, meta_model_name: String, outpost_set: Vec<String>) -> LdapProvider {
LdapProvider {
pk,
name,
authentication_flow: None,
authorization_flow,
property_mappings: None,
component,
assigned_application_slug,
assigned_application_name,
assigned_backchannel_application_slug,
assigned_backchannel_application_name,
verbose_name,
verbose_name_plural,
meta_model_name,
base_dn: None,
search_group: None,
certificate: None,
tls_server_name: None,
uid_start_number: None,
gid_start_number: None,
outpost_set,
search_mode: None,
bind_mode: None,
mfa_support: None,
}
}
}