use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct WsFederationProvider {
#[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 = "invalidation_flow")]
pub invalidation_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", deserialize_with = "Option::deserialize")]
pub assigned_application_slug: Option<String>,
#[serde(rename = "assigned_application_name", deserialize_with = "Option::deserialize")]
pub assigned_application_name: Option<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 = "reply_url")]
pub reply_url: String,
#[serde(rename = "wtrealm")]
pub wtrealm: String,
#[serde(rename = "assertion_valid_not_before", skip_serializing_if = "Option::is_none")]
pub assertion_valid_not_before: Option<String>,
#[serde(rename = "assertion_valid_not_on_or_after", skip_serializing_if = "Option::is_none")]
pub assertion_valid_not_on_or_after: Option<String>,
#[serde(rename = "session_valid_not_on_or_after", skip_serializing_if = "Option::is_none")]
pub session_valid_not_on_or_after: Option<String>,
#[serde(
rename = "name_id_mapping",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub name_id_mapping: Option<Option<uuid::Uuid>>,
#[serde(
rename = "authn_context_class_ref_mapping",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub authn_context_class_ref_mapping: Option<Option<uuid::Uuid>>,
#[serde(rename = "digest_algorithm", skip_serializing_if = "Option::is_none")]
pub digest_algorithm: Option<models::DigestAlgorithmEnum>,
#[serde(rename = "signature_algorithm", skip_serializing_if = "Option::is_none")]
pub signature_algorithm: Option<models::SignatureAlgorithmEnum>,
#[serde(
rename = "signing_kp",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub signing_kp: Option<Option<uuid::Uuid>>,
#[serde(
rename = "encryption_kp",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub encryption_kp: Option<Option<uuid::Uuid>>,
#[serde(rename = "sign_assertion", skip_serializing_if = "Option::is_none")]
pub sign_assertion: Option<bool>,
#[serde(rename = "sign_logout_request", skip_serializing_if = "Option::is_none")]
pub sign_logout_request: Option<bool>,
#[serde(rename = "default_name_id_policy", skip_serializing_if = "Option::is_none")]
pub default_name_id_policy: Option<models::SamlNameIdPolicyEnum>,
#[serde(rename = "url_download_metadata")]
pub url_download_metadata: String,
#[serde(rename = "url_wsfed")]
pub url_wsfed: String,
}
impl WsFederationProvider {
pub fn new(
pk: i32,
name: String,
authorization_flow: uuid::Uuid,
invalidation_flow: uuid::Uuid,
component: String,
assigned_application_slug: Option<String>,
assigned_application_name: Option<String>,
assigned_backchannel_application_slug: Option<String>,
assigned_backchannel_application_name: Option<String>,
verbose_name: String,
verbose_name_plural: String,
meta_model_name: String,
reply_url: String,
wtrealm: String,
url_download_metadata: String,
url_wsfed: String,
) -> WsFederationProvider {
WsFederationProvider {
pk,
name,
authentication_flow: None,
authorization_flow,
invalidation_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,
reply_url,
wtrealm,
assertion_valid_not_before: None,
assertion_valid_not_on_or_after: None,
session_valid_not_on_or_after: None,
name_id_mapping: None,
authn_context_class_ref_mapping: None,
digest_algorithm: None,
signature_algorithm: None,
signing_kp: None,
encryption_kp: None,
sign_assertion: None,
sign_logout_request: None,
default_name_id_policy: None,
url_download_metadata,
url_wsfed,
}
}
}