use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct OAuth2Provider {
#[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_type", skip_serializing_if = "Option::is_none")]
pub client_type: Option<models::ClientTypeEnum>,
#[serde(rename = "client_id", skip_serializing_if = "Option::is_none")]
pub client_id: Option<String>,
#[serde(rename = "client_secret", skip_serializing_if = "Option::is_none")]
pub client_secret: Option<String>,
#[serde(rename = "access_code_validity", skip_serializing_if = "Option::is_none")]
pub access_code_validity: Option<String>,
#[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 = "include_claims_in_id_token", skip_serializing_if = "Option::is_none")]
pub include_claims_in_id_token: Option<bool>,
#[serde(
rename = "signing_key",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub signing_key: Option<Option<uuid::Uuid>>,
#[serde(
rename = "encryption_key",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub encryption_key: Option<Option<uuid::Uuid>>,
#[serde(rename = "redirect_uris")]
pub redirect_uris: Vec<models::RedirectUri>,
#[serde(rename = "sub_mode", skip_serializing_if = "Option::is_none")]
pub sub_mode: Option<models::SubModeEnum>,
#[serde(rename = "issuer_mode", skip_serializing_if = "Option::is_none")]
pub issuer_mode: Option<models::IssuerModeEnum>,
#[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>>,
}
impl OAuth2Provider {
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,
redirect_uris: Vec<models::RedirectUri>,
) -> OAuth2Provider {
OAuth2Provider {
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_type: None,
client_id: None,
client_secret: None,
access_code_validity: None,
access_token_validity: None,
refresh_token_validity: None,
include_claims_in_id_token: None,
signing_key: None,
encryption_key: None,
redirect_uris,
sub_mode: None,
issuer_mode: None,
jwt_federation_sources: None,
jwt_federation_providers: None,
}
}
}