use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct PatchedKerberosSourceRequest {
#[serde(rename = "name", skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[serde(rename = "slug", skip_serializing_if = "Option::is_none")]
pub slug: Option<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 = "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 = "user_path_template", skip_serializing_if = "Option::is_none")]
pub user_path_template: Option<String>,
#[serde(rename = "group_matching_mode", skip_serializing_if = "Option::is_none")]
pub group_matching_mode: Option<models::GroupMatchingModeEnum>,
#[serde(rename = "realm", skip_serializing_if = "Option::is_none")]
pub realm: Option<String>,
#[serde(rename = "krb5_conf", skip_serializing_if = "Option::is_none")]
pub krb5_conf: Option<String>,
#[serde(rename = "kadmin_type", skip_serializing_if = "Option::is_none")]
pub kadmin_type: Option<models::KadminTypeEnum>,
#[serde(rename = "sync_users", skip_serializing_if = "Option::is_none")]
pub sync_users: Option<bool>,
#[serde(rename = "sync_users_password", skip_serializing_if = "Option::is_none")]
pub sync_users_password: Option<bool>,
#[serde(rename = "sync_principal", skip_serializing_if = "Option::is_none")]
pub sync_principal: Option<String>,
#[serde(rename = "sync_password", skip_serializing_if = "Option::is_none")]
pub sync_password: Option<String>,
#[serde(rename = "sync_keytab", skip_serializing_if = "Option::is_none")]
pub sync_keytab: Option<String>,
#[serde(rename = "sync_ccache", skip_serializing_if = "Option::is_none")]
pub sync_ccache: Option<String>,
#[serde(rename = "spnego_server_name", skip_serializing_if = "Option::is_none")]
pub spnego_server_name: Option<String>,
#[serde(rename = "spnego_keytab", skip_serializing_if = "Option::is_none")]
pub spnego_keytab: Option<String>,
#[serde(rename = "spnego_ccache", skip_serializing_if = "Option::is_none")]
pub spnego_ccache: Option<String>,
#[serde(
rename = "password_login_update_internal_password",
skip_serializing_if = "Option::is_none"
)]
pub password_login_update_internal_password: Option<bool>,
}
impl PatchedKerberosSourceRequest {
pub fn new() -> PatchedKerberosSourceRequest {
PatchedKerberosSourceRequest {
name: None,
slug: None,
enabled: None,
authentication_flow: None,
enrollment_flow: None,
user_property_mappings: None,
group_property_mappings: None,
policy_engine_mode: None,
user_matching_mode: None,
user_path_template: None,
group_matching_mode: None,
realm: None,
krb5_conf: None,
kadmin_type: None,
sync_users: None,
sync_users_password: None,
sync_principal: None,
sync_password: None,
sync_keytab: None,
sync_ccache: None,
spnego_server_name: None,
spnego_keytab: None,
spnego_ccache: None,
password_login_update_internal_password: None,
}
}
}