// @generated by jacquard-lexicon. DO NOT EDIT. // // Lexicon: com.atproto.server.createSession // // This file was automatically generated from Lexicon schemas. // Any manual changes will be overwritten on the next regeneration. #[jacquard_derive::lexicon] #[derive( serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq, jacquard_derive::IntoStatic, Default )] #[serde(rename_all = "camelCase")] pub struct CreateSession<'a> { /// When true, instead of throwing error for takendown accounts, a valid response with a narrow scoped token will be returned #[serde(skip_serializing_if = "std::option::Option::is_none")] pub allow_takendown: std::option::Option, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub auth_factor_token: std::option::Option>, /// Handle or other identifier supported by the server for the authenticating user. #[serde(borrow)] pub identifier: jacquard_common::CowStr<'a>, #[serde(borrow)] pub password: jacquard_common::CowStr<'a>, } #[jacquard_derive::lexicon] #[derive( serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq, jacquard_derive::IntoStatic )] #[serde(rename_all = "camelCase")] pub struct CreateSessionOutput<'a> { #[serde(borrow)] pub access_jwt: jacquard_common::CowStr<'a>, #[serde(skip_serializing_if = "std::option::Option::is_none")] pub active: std::option::Option, #[serde(borrow)] pub did: jacquard_common::types::string::Did<'a>, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub did_doc: std::option::Option>, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub email: std::option::Option>, #[serde(skip_serializing_if = "std::option::Option::is_none")] pub email_auth_factor: std::option::Option, #[serde(skip_serializing_if = "std::option::Option::is_none")] pub email_confirmed: std::option::Option, #[serde(borrow)] pub handle: jacquard_common::types::string::Handle<'a>, #[serde(borrow)] pub refresh_jwt: jacquard_common::CowStr<'a>, /// If active=false, this optional field indicates a possible reason for why the account is not active. If active=false and no status is supplied, then the host makes no claim for why the repository is no longer being hosted. #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub status: std::option::Option>, } /// If active=false, this optional field indicates a possible reason for why the account is not active. If active=false and no status is supplied, then the host makes no claim for why the repository is no longer being hosted. #[derive(Debug, Clone, PartialEq, Eq, Hash)] pub enum CreateSessionOutputStatus<'a> { Takendown, Suspended, Deactivated, Other(jacquard_common::CowStr<'a>), } impl<'a> CreateSessionOutputStatus<'a> { pub fn as_str(&self) -> &str { match self { Self::Takendown => "takendown", Self::Suspended => "suspended", Self::Deactivated => "deactivated", Self::Other(s) => s.as_ref(), } } } impl<'a> From<&'a str> for CreateSessionOutputStatus<'a> { fn from(s: &'a str) -> Self { match s { "takendown" => Self::Takendown, "suspended" => Self::Suspended, "deactivated" => Self::Deactivated, _ => Self::Other(jacquard_common::CowStr::from(s)), } } } impl<'a> From for CreateSessionOutputStatus<'a> { fn from(s: String) -> Self { match s.as_str() { "takendown" => Self::Takendown, "suspended" => Self::Suspended, "deactivated" => Self::Deactivated, _ => Self::Other(jacquard_common::CowStr::from(s)), } } } impl<'a> core::fmt::Display for CreateSessionOutputStatus<'a> { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { write!(f, "{}", self.as_str()) } } impl<'a> AsRef for CreateSessionOutputStatus<'a> { fn as_ref(&self) -> &str { self.as_str() } } impl<'a> serde::Serialize for CreateSessionOutputStatus<'a> { fn serialize(&self, serializer: S) -> Result where S: serde::Serializer, { serializer.serialize_str(self.as_str()) } } impl<'de, 'a> serde::Deserialize<'de> for CreateSessionOutputStatus<'a> where 'de: 'a, { fn deserialize(deserializer: D) -> Result where D: serde::Deserializer<'de>, { let s = <&'de str>::deserialize(deserializer)?; Ok(Self::from(s)) } } impl<'a> Default for CreateSessionOutputStatus<'a> { fn default() -> Self { Self::Other(Default::default()) } } impl jacquard_common::IntoStatic for CreateSessionOutputStatus<'_> { type Output = CreateSessionOutputStatus<'static>; fn into_static(self) -> Self::Output { match self { CreateSessionOutputStatus::Takendown => CreateSessionOutputStatus::Takendown, CreateSessionOutputStatus::Suspended => CreateSessionOutputStatus::Suspended, CreateSessionOutputStatus::Deactivated => { CreateSessionOutputStatus::Deactivated } CreateSessionOutputStatus::Other(v) => { CreateSessionOutputStatus::Other(v.into_static()) } } } } #[jacquard_derive::open_union] #[derive( serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq, thiserror::Error, miette::Diagnostic, jacquard_derive::IntoStatic )] #[serde(tag = "error", content = "message")] #[serde(bound(deserialize = "'de: 'a"))] pub enum CreateSessionError<'a> { #[serde(rename = "AccountTakedown")] AccountTakedown(std::option::Option>), #[serde(rename = "AuthFactorTokenRequired")] AuthFactorTokenRequired(std::option::Option>), } impl core::fmt::Display for CreateSessionError<'_> { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { match self { Self::AccountTakedown(msg) => { write!(f, "AccountTakedown")?; if let Some(msg) = msg { write!(f, ": {}", msg)?; } Ok(()) } Self::AuthFactorTokenRequired(msg) => { write!(f, "AuthFactorTokenRequired")?; if let Some(msg) = msg { write!(f, ": {}", msg)?; } Ok(()) } Self::Unknown(err) => write!(f, "Unknown error: {:?}", err), } } } /// Response type for ///com.atproto.server.createSession pub struct CreateSessionResponse; impl jacquard_common::xrpc::XrpcResp for CreateSessionResponse { const NSID: &'static str = "com.atproto.server.createSession"; const ENCODING: &'static str = "application/json"; type Output<'de> = CreateSessionOutput<'de>; type Err<'de> = CreateSessionError<'de>; } impl<'a> jacquard_common::xrpc::XrpcRequest for CreateSession<'a> { const NSID: &'static str = "com.atproto.server.createSession"; const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure( "application/json", ); type Response = CreateSessionResponse; } /// Endpoint type for ///com.atproto.server.createSession pub struct CreateSessionRequest; impl jacquard_common::xrpc::XrpcEndpoint for CreateSessionRequest { const PATH: &'static str = "/xrpc/com.atproto.server.createSession"; const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure( "application/json", ); type Request<'de> = CreateSession<'de>; type Response = CreateSessionResponse; }