use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct ScimProvider {
#[serde(rename = "pk")]
pub pk: i32,
#[serde(rename = "name")]
pub name: String,
#[serde(rename = "property_mappings", skip_serializing_if = "Option::is_none")]
pub property_mappings: Option<Vec<uuid::Uuid>>,
#[serde(rename = "property_mappings_group", skip_serializing_if = "Option::is_none")]
pub property_mappings_group: Option<Vec<uuid::Uuid>>,
#[serde(rename = "component")]
pub component: String,
#[serde(
rename = "assigned_backchannel_application_slug",
deserialize_with = "Option::deserialize"
)]
pub assigned_backchannel_application_slug: Option<String>,
#[serde(
rename = "assigned_backchannel_application_name",
deserialize_with = "Option::deserialize"
)]
pub assigned_backchannel_application_name: Option<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 = "url")]
pub url: String,
#[serde(rename = "verify_certificates", skip_serializing_if = "Option::is_none")]
pub verify_certificates: Option<bool>,
#[serde(rename = "token", skip_serializing_if = "Option::is_none")]
pub token: Option<String>,
#[serde(rename = "auth_mode", skip_serializing_if = "Option::is_none")]
pub auth_mode: Option<models::ScimAuthenticationModeEnum>,
#[serde(
rename = "auth_oauth",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub auth_oauth: Option<Option<uuid::Uuid>>,
#[serde(rename = "auth_oauth_params", skip_serializing_if = "Option::is_none")]
pub auth_oauth_params: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "compatibility_mode", skip_serializing_if = "Option::is_none")]
pub compatibility_mode: Option<models::CompatibilityModeEnum>,
#[serde(
rename = "service_provider_config_cache_timeout",
skip_serializing_if = "Option::is_none"
)]
pub service_provider_config_cache_timeout: Option<String>,
#[serde(rename = "exclude_users_service_account", skip_serializing_if = "Option::is_none")]
pub exclude_users_service_account: Option<bool>,
#[serde(rename = "sync_page_size", skip_serializing_if = "Option::is_none")]
pub sync_page_size: Option<u32>,
#[serde(rename = "sync_page_timeout", skip_serializing_if = "Option::is_none")]
pub sync_page_timeout: Option<String>,
#[serde(rename = "group_filters", skip_serializing_if = "Option::is_none")]
pub group_filters: Option<Vec<uuid::Uuid>>,
#[serde(rename = "dry_run", skip_serializing_if = "Option::is_none")]
pub dry_run: Option<bool>,
}
impl ScimProvider {
pub fn new(
pk: i32,
name: String,
component: String,
assigned_backchannel_application_slug: Option<String>,
assigned_backchannel_application_name: Option<String>,
verbose_name: String,
verbose_name_plural: String,
meta_model_name: String,
url: String,
) -> ScimProvider {
ScimProvider {
pk,
name,
property_mappings: None,
property_mappings_group: None,
component,
assigned_backchannel_application_slug,
assigned_backchannel_application_name,
verbose_name,
verbose_name_plural,
meta_model_name,
url,
verify_certificates: None,
token: None,
auth_mode: None,
auth_oauth: None,
auth_oauth_params: None,
compatibility_mode: None,
service_provider_config_cache_timeout: None,
exclude_users_service_account: None,
sync_page_size: None,
sync_page_timeout: None,
group_filters: None,
dry_run: None,
}
}
}