authentik_client/models/
authenticator_email_challenge.rs1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct AuthenticatorEmailChallenge {
17 #[serde(rename = "flow_info", skip_serializing_if = "Option::is_none")]
18 pub flow_info: Option<models::ContextualFlowInfo>,
19 #[serde(rename = "component", skip_serializing_if = "Option::is_none")]
20 pub component: Option<String>,
21 #[serde(rename = "response_errors", skip_serializing_if = "Option::is_none")]
22 pub response_errors: Option<std::collections::HashMap<String, Vec<models::ErrorDetail>>>,
23 #[serde(rename = "pending_user")]
24 pub pending_user: String,
25 #[serde(rename = "pending_user_avatar")]
26 pub pending_user_avatar: String,
27 #[serde(
28 rename = "email",
29 default,
30 with = "::serde_with::rust::double_option",
31 skip_serializing_if = "Option::is_none"
32 )]
33 pub email: Option<Option<String>>,
34 #[serde(rename = "email_required", skip_serializing_if = "Option::is_none")]
35 pub email_required: Option<bool>,
36}
37
38impl AuthenticatorEmailChallenge {
39 pub fn new(pending_user: String, pending_user_avatar: String) -> AuthenticatorEmailChallenge {
41 AuthenticatorEmailChallenge {
42 flow_info: None,
43 component: None,
44 response_errors: None,
45 pending_user,
46 pending_user_avatar,
47 email: None,
48 email_required: None,
49 }
50 }
51}