use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct ProxyProvider {
#[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")]
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 = "client_id")]
pub client_id: String,
#[serde(rename = "internal_host", skip_serializing_if = "Option::is_none")]
pub internal_host: Option<String>,
#[serde(rename = "external_host")]
pub external_host: String,
#[serde(rename = "internal_host_ssl_validation", skip_serializing_if = "Option::is_none")]
pub internal_host_ssl_validation: Option<bool>,
#[serde(
rename = "certificate",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub certificate: Option<Option<uuid::Uuid>>,
#[serde(rename = "skip_path_regex", skip_serializing_if = "Option::is_none")]
pub skip_path_regex: Option<String>,
#[serde(rename = "basic_auth_enabled", skip_serializing_if = "Option::is_none")]
pub basic_auth_enabled: Option<bool>,
#[serde(rename = "basic_auth_password_attribute", skip_serializing_if = "Option::is_none")]
pub basic_auth_password_attribute: Option<String>,
#[serde(rename = "basic_auth_user_attribute", skip_serializing_if = "Option::is_none")]
pub basic_auth_user_attribute: Option<String>,
#[serde(rename = "mode", skip_serializing_if = "Option::is_none")]
pub mode: Option<models::ProxyMode>,
#[serde(rename = "intercept_header_auth", skip_serializing_if = "Option::is_none")]
pub intercept_header_auth: Option<bool>,
#[serde(rename = "redirect_uris")]
pub redirect_uris: Vec<models::RedirectUri>,
#[serde(rename = "cookie_domain", skip_serializing_if = "Option::is_none")]
pub cookie_domain: Option<String>,
#[serde(rename = "jwt_federation_sources", skip_serializing_if = "Option::is_none")]
pub jwt_federation_sources: Option<Vec<uuid::Uuid>>,
#[serde(rename = "jwt_federation_providers", skip_serializing_if = "Option::is_none")]
pub jwt_federation_providers: Option<Vec<i32>>,
#[serde(rename = "access_token_validity", skip_serializing_if = "Option::is_none")]
pub access_token_validity: Option<String>,
#[serde(rename = "refresh_token_validity", skip_serializing_if = "Option::is_none")]
pub refresh_token_validity: Option<String>,
#[serde(rename = "outpost_set")]
pub outpost_set: Vec<String>,
}
impl ProxyProvider {
pub fn new(
pk: i32,
name: String,
authorization_flow: uuid::Uuid,
invalidation_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,
client_id: String,
external_host: String,
redirect_uris: Vec<models::RedirectUri>,
outpost_set: Vec<String>,
) -> ProxyProvider {
ProxyProvider {
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,
client_id,
internal_host: None,
external_host,
internal_host_ssl_validation: None,
certificate: None,
skip_path_regex: None,
basic_auth_enabled: None,
basic_auth_password_attribute: None,
basic_auth_user_attribute: None,
mode: None,
intercept_header_auth: None,
redirect_uris,
cookie_domain: None,
jwt_federation_sources: None,
jwt_federation_providers: None,
access_token_validity: None,
refresh_token_validity: None,
outpost_set,
}
}
}