use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct OAuthSource {
#[serde(rename = "pk")]
pub pk: uuid::Uuid,
#[serde(rename = "name")]
pub name: String,
#[serde(rename = "slug")]
pub slug: String,
#[serde(rename = "enabled", skip_serializing_if = "Option::is_none")]
pub enabled: Option<bool>,
#[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 = "enrollment_flow",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub enrollment_flow: Option<Option<uuid::Uuid>>,
#[serde(rename = "user_property_mappings", skip_serializing_if = "Option::is_none")]
pub user_property_mappings: Option<Vec<uuid::Uuid>>,
#[serde(rename = "group_property_mappings", skip_serializing_if = "Option::is_none")]
pub group_property_mappings: Option<Vec<uuid::Uuid>>,
#[serde(rename = "component")]
pub component: 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 = "policy_engine_mode", skip_serializing_if = "Option::is_none")]
pub policy_engine_mode: Option<models::PolicyEngineMode>,
#[serde(rename = "user_matching_mode", skip_serializing_if = "Option::is_none")]
pub user_matching_mode: Option<models::UserMatchingModeEnum>,
#[serde(rename = "managed", deserialize_with = "Option::deserialize")]
pub managed: Option<String>,
#[serde(rename = "user_path_template", skip_serializing_if = "Option::is_none")]
pub user_path_template: Option<String>,
#[serde(rename = "icon", deserialize_with = "Option::deserialize")]
pub icon: Option<String>,
#[serde(rename = "group_matching_mode", skip_serializing_if = "Option::is_none")]
pub group_matching_mode: Option<models::GroupMatchingModeEnum>,
#[serde(rename = "provider_type")]
pub provider_type: models::ProviderTypeEnum,
#[serde(
rename = "request_token_url",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub request_token_url: Option<Option<String>>,
#[serde(
rename = "authorization_url",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub authorization_url: Option<Option<String>>,
#[serde(
rename = "access_token_url",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub access_token_url: Option<Option<String>>,
#[serde(
rename = "profile_url",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub profile_url: Option<Option<String>>,
#[serde(rename = "consumer_key")]
pub consumer_key: String,
#[serde(rename = "callback_url")]
pub callback_url: String,
#[serde(rename = "additional_scopes", skip_serializing_if = "Option::is_none")]
pub additional_scopes: Option<String>,
#[serde(rename = "type")]
pub r#type: models::SourceType,
#[serde(rename = "oidc_well_known_url", skip_serializing_if = "Option::is_none")]
pub oidc_well_known_url: Option<String>,
#[serde(rename = "oidc_jwks_url", skip_serializing_if = "Option::is_none")]
pub oidc_jwks_url: Option<String>,
#[serde(
rename = "oidc_jwks",
default,
with = "::serde_with::rust::double_option",
skip_serializing_if = "Option::is_none"
)]
pub oidc_jwks: Option<Option<serde_json::Value>>,
}
impl OAuthSource {
pub fn new(
pk: uuid::Uuid,
name: String,
slug: String,
component: String,
verbose_name: String,
verbose_name_plural: String,
meta_model_name: String,
managed: Option<String>,
icon: Option<String>,
provider_type: models::ProviderTypeEnum,
consumer_key: String,
callback_url: String,
r#type: models::SourceType,
) -> OAuthSource {
OAuthSource {
pk,
name,
slug,
enabled: None,
authentication_flow: None,
enrollment_flow: None,
user_property_mappings: None,
group_property_mappings: None,
component,
verbose_name,
verbose_name_plural,
meta_model_name,
policy_engine_mode: None,
user_matching_mode: None,
managed,
user_path_template: None,
icon,
group_matching_mode: None,
provider_type,
request_token_url: None,
authorization_url: None,
access_token_url: None,
profile_url: None,
consumer_key,
callback_url,
additional_scopes: None,
r#type,
oidc_well_known_url: None,
oidc_jwks_url: None,
oidc_jwks: None,
}
}
}