1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119

use crate::types::*;
use crate::errors::*;
use uuid::Uuid;




/// Represents the current state of 2-step verification
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct PasswordState {
  #[doc(hidden)]
  #[serde(rename(serialize = "@type", deserialize = "@type"))]
  td_name: String,
  #[doc(hidden)]
  #[serde(rename(serialize = "@extra", deserialize = "@extra"))]
  extra: Option<String>,
  /// True, if a 2-step verification password is set
  has_password: bool,
  /// Hint for the password; may be empty
  password_hint: String,
  /// True, if a recovery email is set
  has_recovery_email_address: bool,
  /// True, if some Telegram Passport elements were saved
  has_passport_data: bool,
  /// Information about the recovery email address to which the confirmation email was sent; may be null
  recovery_email_address_code_info: Option<EmailAddressAuthenticationCodeInfo>,
  /// If not 0, point in time (Unix timestamp) after which the password can be reset immediately using resetPassword
  pending_reset_date: i64,
  
}

impl RObject for PasswordState {
  #[doc(hidden)] fn td_name(&self) -> &'static str { "passwordState" }
  #[doc(hidden)] fn extra(&self) -> Option<String> { self.extra.clone() }
  fn to_json(&self) -> RTDResult<String> { Ok(serde_json::to_string(self)?) }
}



impl PasswordState {
  pub fn from_json<S: AsRef<str>>(json: S) -> RTDResult<Self> { Ok(serde_json::from_str(json.as_ref())?) }
  pub fn builder() -> RTDPasswordStateBuilder {
    let mut inner = PasswordState::default();
    inner.td_name = "passwordState".to_string();
    inner.extra = Some(Uuid::new_v4().to_string());
    RTDPasswordStateBuilder { inner }
  }

  pub fn has_password(&self) -> bool { self.has_password }

  pub fn password_hint(&self) -> &String { &self.password_hint }

  pub fn has_recovery_email_address(&self) -> bool { self.has_recovery_email_address }

  pub fn has_passport_data(&self) -> bool { self.has_passport_data }

  pub fn recovery_email_address_code_info(&self) -> &Option<EmailAddressAuthenticationCodeInfo> { &self.recovery_email_address_code_info }

  pub fn pending_reset_date(&self) -> i64 { self.pending_reset_date }

}

#[doc(hidden)]
pub struct RTDPasswordStateBuilder {
  inner: PasswordState
}

impl RTDPasswordStateBuilder {
  pub fn build(&self) -> PasswordState { self.inner.clone() }

   
  pub fn has_password(&mut self, has_password: bool) -> &mut Self {
    self.inner.has_password = has_password;
    self
  }

   
  pub fn password_hint<T: AsRef<str>>(&mut self, password_hint: T) -> &mut Self {
    self.inner.password_hint = password_hint.as_ref().to_string();
    self
  }

   
  pub fn has_recovery_email_address(&mut self, has_recovery_email_address: bool) -> &mut Self {
    self.inner.has_recovery_email_address = has_recovery_email_address;
    self
  }

   
  pub fn has_passport_data(&mut self, has_passport_data: bool) -> &mut Self {
    self.inner.has_passport_data = has_passport_data;
    self
  }

   
  pub fn recovery_email_address_code_info<T: AsRef<EmailAddressAuthenticationCodeInfo>>(&mut self, recovery_email_address_code_info: T) -> &mut Self {
    self.inner.recovery_email_address_code_info = Some(recovery_email_address_code_info.as_ref().clone());
    self
  }

   
  pub fn pending_reset_date(&mut self, pending_reset_date: i64) -> &mut Self {
    self.inner.pending_reset_date = pending_reset_date;
    self
  }

}

impl AsRef<PasswordState> for PasswordState {
  fn as_ref(&self) -> &PasswordState { self }
}

impl AsRef<PasswordState> for RTDPasswordStateBuilder {
  fn as_ref(&self) -> &PasswordState { &self.inner }
}