use crate::errors::Result;
use crate::types::*;
use uuid::Uuid;
use std::fmt::Debug;
pub trait TDPublicChatType: Debug + RObject {}
#[derive(Debug, Clone, Deserialize, Serialize, Default)]
#[serde(tag = "@type")]
pub enum PublicChatType {
#[doc(hidden)]
#[default]
_Default,
#[serde(rename = "publicChatTypeHasUsername")]
HasUsername(PublicChatTypeHasUsername),
#[serde(rename = "publicChatTypeIsLocationBased")]
IsLocationBased(PublicChatTypeIsLocationBased),
}
impl RObject for PublicChatType {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
match self {
PublicChatType::HasUsername(t) => t.extra(),
PublicChatType::IsLocationBased(t) => t.extra(),
_ => None,
}
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
match self {
PublicChatType::HasUsername(t) => t.client_id(),
PublicChatType::IsLocationBased(t) => t.client_id(),
_ => None,
}
}
}
impl PublicChatType {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
#[doc(hidden)]
pub fn _is_default(&self) -> bool {
matches!(self, PublicChatType::_Default)
}
}
impl AsRef<PublicChatType> for PublicChatType {
fn as_ref(&self) -> &PublicChatType {
self
}
}
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct PublicChatTypeHasUsername {
#[doc(hidden)]
#[serde(rename(serialize = "@extra", deserialize = "@extra"))]
extra: Option<String>,
#[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
client_id: Option<i32>,
}
impl RObject for PublicChatTypeHasUsername {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
self.extra.as_deref()
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
self.client_id
}
}
impl TDPublicChatType for PublicChatTypeHasUsername {}
impl PublicChatTypeHasUsername {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
pub fn builder() -> PublicChatTypeHasUsernameBuilder {
let mut inner = PublicChatTypeHasUsername::default();
inner.extra = Some(Uuid::new_v4().to_string());
PublicChatTypeHasUsernameBuilder { inner }
}
}
#[doc(hidden)]
pub struct PublicChatTypeHasUsernameBuilder {
inner: PublicChatTypeHasUsername,
}
#[deprecated]
pub type RTDPublicChatTypeHasUsernameBuilder = PublicChatTypeHasUsernameBuilder;
impl PublicChatTypeHasUsernameBuilder {
pub fn build(&self) -> PublicChatTypeHasUsername {
self.inner.clone()
}
}
impl AsRef<PublicChatTypeHasUsername> for PublicChatTypeHasUsername {
fn as_ref(&self) -> &PublicChatTypeHasUsername {
self
}
}
impl AsRef<PublicChatTypeHasUsername> for PublicChatTypeHasUsernameBuilder {
fn as_ref(&self) -> &PublicChatTypeHasUsername {
&self.inner
}
}
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct PublicChatTypeIsLocationBased {
#[doc(hidden)]
#[serde(rename(serialize = "@extra", deserialize = "@extra"))]
extra: Option<String>,
#[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
client_id: Option<i32>,
}
impl RObject for PublicChatTypeIsLocationBased {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
self.extra.as_deref()
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
self.client_id
}
}
impl TDPublicChatType for PublicChatTypeIsLocationBased {}
impl PublicChatTypeIsLocationBased {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
pub fn builder() -> PublicChatTypeIsLocationBasedBuilder {
let mut inner = PublicChatTypeIsLocationBased::default();
inner.extra = Some(Uuid::new_v4().to_string());
PublicChatTypeIsLocationBasedBuilder { inner }
}
}
#[doc(hidden)]
pub struct PublicChatTypeIsLocationBasedBuilder {
inner: PublicChatTypeIsLocationBased,
}
#[deprecated]
pub type RTDPublicChatTypeIsLocationBasedBuilder = PublicChatTypeIsLocationBasedBuilder;
impl PublicChatTypeIsLocationBasedBuilder {
pub fn build(&self) -> PublicChatTypeIsLocationBased {
self.inner.clone()
}
}
impl AsRef<PublicChatTypeIsLocationBased> for PublicChatTypeIsLocationBased {
fn as_ref(&self) -> &PublicChatTypeIsLocationBased {
self
}
}
impl AsRef<PublicChatTypeIsLocationBased> for PublicChatTypeIsLocationBasedBuilder {
fn as_ref(&self) -> &PublicChatTypeIsLocationBased {
&self.inner
}
}