pub mod activate_account;
pub mod check_account_status;
pub mod confirm_email;
pub mod create_account;
pub mod create_app_password;
pub mod create_invite_code;
pub mod create_invite_codes;
pub mod create_session;
pub mod deactivate_account;
pub mod delete_account;
pub mod delete_session;
pub mod describe_server;
pub mod get_account_invite_codes;
pub mod get_service_auth;
pub mod get_session;
pub mod list_app_passwords;
pub mod refresh_session;
pub mod request_account_delete;
pub mod request_email_confirmation;
pub mod request_email_update;
pub mod request_password_reset;
pub mod reserve_signing_key;
pub mod reset_password;
pub mod revoke_app_password;
pub mod update_email;
#[allow(unused_imports)]
use alloc::collections::BTreeMap;
#[allow(unused_imports)]
use core::marker::PhantomData;
use jacquard_common::{BosStr, CowStr, DefaultStr, FromStaticStr};
#[allow(unused_imports)]
use jacquard_common::deps::codegen::unicode_segmentation::UnicodeSegmentation;
use jacquard_common::deps::smol_str::SmolStr;
use jacquard_common::types::string::{Datetime, Did};
use jacquard_common::types::value::Data;
use jacquard_derive::IntoStatic;
use jacquard_lexicon::lexicon::LexiconDoc;
use jacquard_lexicon::schema::LexiconSchema;
use crate::com_atproto::server;
#[allow(unused_imports)]
use jacquard_lexicon::validation::{ConstraintError, ValidationPath};
use serde::{Deserialize, Serialize};
#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq, IntoStatic)]
#[serde(
rename_all = "camelCase",
bound(deserialize = "S: Deserialize<'de> + BosStr")
)]
pub struct InviteCode<S: BosStr = DefaultStr> {
pub available: i64,
pub code: S,
pub created_at: Datetime,
pub created_by: S,
pub disabled: bool,
pub for_account: S,
pub uses: Vec<server::InviteCodeUse<S>>,
#[serde(flatten, default, skip_serializing_if = "Option::is_none")]
pub extra_data: Option<BTreeMap<SmolStr, Data<S>>>,
}
#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq, IntoStatic)]
#[serde(
rename_all = "camelCase",
bound(deserialize = "S: Deserialize<'de> + BosStr")
)]
pub struct InviteCodeUse<S: BosStr = DefaultStr> {
pub used_at: Datetime,
pub used_by: Did<S>,
#[serde(flatten, default, skip_serializing_if = "Option::is_none")]
pub extra_data: Option<BTreeMap<SmolStr, Data<S>>>,
}
impl<S: BosStr> LexiconSchema for InviteCode<S> {
fn nsid() -> &'static str {
"com.atproto.server.defs"
}
fn def_name() -> &'static str {
"inviteCode"
}
fn lexicon_doc() -> LexiconDoc<'static> {
lexicon_doc_com_atproto_server_defs()
}
fn validate(&self) -> Result<(), ConstraintError> {
Ok(())
}
}
impl<S: BosStr> LexiconSchema for InviteCodeUse<S> {
fn nsid() -> &'static str {
"com.atproto.server.defs"
}
fn def_name() -> &'static str {
"inviteCodeUse"
}
fn lexicon_doc() -> LexiconDoc<'static> {
lexicon_doc_com_atproto_server_defs()
}
fn validate(&self) -> Result<(), ConstraintError> {
Ok(())
}
}
pub mod invite_code_state {
pub use crate::builder_types::{IsSet, IsUnset, Set, Unset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type CreatedAt;
type ForAccount;
type Uses;
type Code;
type Available;
type Disabled;
type CreatedBy;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type CreatedAt = Unset;
type ForAccount = Unset;
type Uses = Unset;
type Code = Unset;
type Available = Unset;
type Disabled = Unset;
type CreatedBy = Unset;
}
pub struct SetCreatedAt<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetCreatedAt<St> {}
impl<St: State> State for SetCreatedAt<St> {
type CreatedAt = Set<members::created_at>;
type ForAccount = St::ForAccount;
type Uses = St::Uses;
type Code = St::Code;
type Available = St::Available;
type Disabled = St::Disabled;
type CreatedBy = St::CreatedBy;
}
pub struct SetForAccount<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetForAccount<St> {}
impl<St: State> State for SetForAccount<St> {
type CreatedAt = St::CreatedAt;
type ForAccount = Set<members::for_account>;
type Uses = St::Uses;
type Code = St::Code;
type Available = St::Available;
type Disabled = St::Disabled;
type CreatedBy = St::CreatedBy;
}
pub struct SetUses<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetUses<St> {}
impl<St: State> State for SetUses<St> {
type CreatedAt = St::CreatedAt;
type ForAccount = St::ForAccount;
type Uses = Set<members::uses>;
type Code = St::Code;
type Available = St::Available;
type Disabled = St::Disabled;
type CreatedBy = St::CreatedBy;
}
pub struct SetCode<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetCode<St> {}
impl<St: State> State for SetCode<St> {
type CreatedAt = St::CreatedAt;
type ForAccount = St::ForAccount;
type Uses = St::Uses;
type Code = Set<members::code>;
type Available = St::Available;
type Disabled = St::Disabled;
type CreatedBy = St::CreatedBy;
}
pub struct SetAvailable<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetAvailable<St> {}
impl<St: State> State for SetAvailable<St> {
type CreatedAt = St::CreatedAt;
type ForAccount = St::ForAccount;
type Uses = St::Uses;
type Code = St::Code;
type Available = Set<members::available>;
type Disabled = St::Disabled;
type CreatedBy = St::CreatedBy;
}
pub struct SetDisabled<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetDisabled<St> {}
impl<St: State> State for SetDisabled<St> {
type CreatedAt = St::CreatedAt;
type ForAccount = St::ForAccount;
type Uses = St::Uses;
type Code = St::Code;
type Available = St::Available;
type Disabled = Set<members::disabled>;
type CreatedBy = St::CreatedBy;
}
pub struct SetCreatedBy<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetCreatedBy<St> {}
impl<St: State> State for SetCreatedBy<St> {
type CreatedAt = St::CreatedAt;
type ForAccount = St::ForAccount;
type Uses = St::Uses;
type Code = St::Code;
type Available = St::Available;
type Disabled = St::Disabled;
type CreatedBy = Set<members::created_by>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct created_at(());
pub struct for_account(());
pub struct uses(());
pub struct code(());
pub struct available(());
pub struct disabled(());
pub struct created_by(());
}
}
pub struct InviteCodeBuilder<S: BosStr, St: invite_code_state::State> {
_state: PhantomData<fn() -> St>,
_fields: (
Option<i64>,
Option<S>,
Option<Datetime>,
Option<S>,
Option<bool>,
Option<S>,
Option<Vec<server::InviteCodeUse<S>>>,
),
_type: PhantomData<fn() -> S>,
}
impl<S: BosStr> InviteCode<S> {
pub fn new() -> InviteCodeBuilder<S, invite_code_state::Empty> {
InviteCodeBuilder::new()
}
}
impl<S: BosStr> InviteCodeBuilder<S, invite_code_state::Empty> {
pub fn new() -> Self {
InviteCodeBuilder {
_state: PhantomData,
_fields: (None, None, None, None, None, None, None),
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::Available: invite_code_state::IsUnset,
{
pub fn available(
mut self,
value: impl Into<i64>,
) -> InviteCodeBuilder<S, invite_code_state::SetAvailable<St>> {
self._fields.0 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::Code: invite_code_state::IsUnset,
{
pub fn code(
mut self,
value: impl Into<S>,
) -> InviteCodeBuilder<S, invite_code_state::SetCode<St>> {
self._fields.1 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::CreatedAt: invite_code_state::IsUnset,
{
pub fn created_at(
mut self,
value: impl Into<Datetime>,
) -> InviteCodeBuilder<S, invite_code_state::SetCreatedAt<St>> {
self._fields.2 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::CreatedBy: invite_code_state::IsUnset,
{
pub fn created_by(
mut self,
value: impl Into<S>,
) -> InviteCodeBuilder<S, invite_code_state::SetCreatedBy<St>> {
self._fields.3 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::Disabled: invite_code_state::IsUnset,
{
pub fn disabled(
mut self,
value: impl Into<bool>,
) -> InviteCodeBuilder<S, invite_code_state::SetDisabled<St>> {
self._fields.4 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::ForAccount: invite_code_state::IsUnset,
{
pub fn for_account(
mut self,
value: impl Into<S>,
) -> InviteCodeBuilder<S, invite_code_state::SetForAccount<St>> {
self._fields.5 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::Uses: invite_code_state::IsUnset,
{
pub fn uses(
mut self,
value: impl Into<Vec<server::InviteCodeUse<S>>>,
) -> InviteCodeBuilder<S, invite_code_state::SetUses<St>> {
self._fields.6 = Option::Some(value.into());
InviteCodeBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeBuilder<S, St>
where
St: invite_code_state::State,
St::CreatedAt: invite_code_state::IsSet,
St::ForAccount: invite_code_state::IsSet,
St::Uses: invite_code_state::IsSet,
St::Code: invite_code_state::IsSet,
St::Available: invite_code_state::IsSet,
St::Disabled: invite_code_state::IsSet,
St::CreatedBy: invite_code_state::IsSet,
{
pub fn build(self) -> InviteCode<S> {
InviteCode {
available: self._fields.0.unwrap(),
code: self._fields.1.unwrap(),
created_at: self._fields.2.unwrap(),
created_by: self._fields.3.unwrap(),
disabled: self._fields.4.unwrap(),
for_account: self._fields.5.unwrap(),
uses: self._fields.6.unwrap(),
extra_data: Default::default(),
}
}
pub fn build_with_data(self, extra_data: BTreeMap<SmolStr, Data<S>>) -> InviteCode<S> {
InviteCode {
available: self._fields.0.unwrap(),
code: self._fields.1.unwrap(),
created_at: self._fields.2.unwrap(),
created_by: self._fields.3.unwrap(),
disabled: self._fields.4.unwrap(),
for_account: self._fields.5.unwrap(),
uses: self._fields.6.unwrap(),
extra_data: Some(extra_data),
}
}
}
fn lexicon_doc_com_atproto_server_defs() -> LexiconDoc<'static> {
use alloc::collections::BTreeMap;
#[allow(unused_imports)]
use jacquard_common::{CowStr, deps::smol_str::SmolStr, types::blob::MimeType};
use jacquard_lexicon::lexicon::*;
LexiconDoc {
lexicon: Lexicon::Lexicon1,
id: CowStr::new_static("com.atproto.server.defs"),
defs: {
let mut map = BTreeMap::new();
map.insert(
SmolStr::new_static("inviteCode"),
LexUserType::Object(LexObject {
required: Some(vec![
SmolStr::new_static("code"),
SmolStr::new_static("available"),
SmolStr::new_static("disabled"),
SmolStr::new_static("forAccount"),
SmolStr::new_static("createdBy"),
SmolStr::new_static("createdAt"),
SmolStr::new_static("uses"),
]),
properties: {
#[allow(unused_mut)]
let mut map = BTreeMap::new();
map.insert(
SmolStr::new_static("available"),
LexObjectProperty::Integer(LexInteger {
..Default::default()
}),
);
map.insert(
SmolStr::new_static("code"),
LexObjectProperty::String(LexString {
..Default::default()
}),
);
map.insert(
SmolStr::new_static("createdAt"),
LexObjectProperty::String(LexString {
format: Some(LexStringFormat::Datetime),
..Default::default()
}),
);
map.insert(
SmolStr::new_static("createdBy"),
LexObjectProperty::String(LexString {
..Default::default()
}),
);
map.insert(
SmolStr::new_static("disabled"),
LexObjectProperty::Boolean(LexBoolean {
..Default::default()
}),
);
map.insert(
SmolStr::new_static("forAccount"),
LexObjectProperty::String(LexString {
..Default::default()
}),
);
map.insert(
SmolStr::new_static("uses"),
LexObjectProperty::Array(LexArray {
items: LexArrayItem::Ref(LexRef {
r#ref: CowStr::new_static("#inviteCodeUse"),
..Default::default()
}),
..Default::default()
}),
);
map
},
..Default::default()
}),
);
map.insert(
SmolStr::new_static("inviteCodeUse"),
LexUserType::Object(LexObject {
required: Some(vec![
SmolStr::new_static("usedBy"),
SmolStr::new_static("usedAt"),
]),
properties: {
#[allow(unused_mut)]
let mut map = BTreeMap::new();
map.insert(
SmolStr::new_static("usedAt"),
LexObjectProperty::String(LexString {
format: Some(LexStringFormat::Datetime),
..Default::default()
}),
);
map.insert(
SmolStr::new_static("usedBy"),
LexObjectProperty::String(LexString {
format: Some(LexStringFormat::Did),
..Default::default()
}),
);
map
},
..Default::default()
}),
);
map
},
..Default::default()
}
}
pub mod invite_code_use_state {
pub use crate::builder_types::{IsSet, IsUnset, Set, Unset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type UsedBy;
type UsedAt;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type UsedBy = Unset;
type UsedAt = Unset;
}
pub struct SetUsedBy<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetUsedBy<St> {}
impl<St: State> State for SetUsedBy<St> {
type UsedBy = Set<members::used_by>;
type UsedAt = St::UsedAt;
}
pub struct SetUsedAt<St: State = Empty>(PhantomData<fn() -> St>);
impl<St: State> sealed::Sealed for SetUsedAt<St> {}
impl<St: State> State for SetUsedAt<St> {
type UsedBy = St::UsedBy;
type UsedAt = Set<members::used_at>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct used_by(());
pub struct used_at(());
}
}
pub struct InviteCodeUseBuilder<S: BosStr, St: invite_code_use_state::State> {
_state: PhantomData<fn() -> St>,
_fields: (Option<Datetime>, Option<Did<S>>),
_type: PhantomData<fn() -> S>,
}
impl<S: BosStr> InviteCodeUse<S> {
pub fn new() -> InviteCodeUseBuilder<S, invite_code_use_state::Empty> {
InviteCodeUseBuilder::new()
}
}
impl<S: BosStr> InviteCodeUseBuilder<S, invite_code_use_state::Empty> {
pub fn new() -> Self {
InviteCodeUseBuilder {
_state: PhantomData,
_fields: (None, None),
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeUseBuilder<S, St>
where
St: invite_code_use_state::State,
St::UsedAt: invite_code_use_state::IsUnset,
{
pub fn used_at(
mut self,
value: impl Into<Datetime>,
) -> InviteCodeUseBuilder<S, invite_code_use_state::SetUsedAt<St>> {
self._fields.0 = Option::Some(value.into());
InviteCodeUseBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeUseBuilder<S, St>
where
St: invite_code_use_state::State,
St::UsedBy: invite_code_use_state::IsUnset,
{
pub fn used_by(
mut self,
value: impl Into<Did<S>>,
) -> InviteCodeUseBuilder<S, invite_code_use_state::SetUsedBy<St>> {
self._fields.1 = Option::Some(value.into());
InviteCodeUseBuilder {
_state: PhantomData,
_fields: self._fields,
_type: PhantomData,
}
}
}
impl<S: BosStr, St> InviteCodeUseBuilder<S, St>
where
St: invite_code_use_state::State,
St::UsedBy: invite_code_use_state::IsSet,
St::UsedAt: invite_code_use_state::IsSet,
{
pub fn build(self) -> InviteCodeUse<S> {
InviteCodeUse {
used_at: self._fields.0.unwrap(),
used_by: self._fields.1.unwrap(),
extra_data: Default::default(),
}
}
pub fn build_with_data(self, extra_data: BTreeMap<SmolStr, Data<S>>) -> InviteCodeUse<S> {
InviteCodeUse {
used_at: self._fields.0.unwrap(),
used_by: self._fields.1.unwrap(),
extra_data: Some(extra_data),
}
}
}