// @generated by jacquard-lexicon. DO NOT EDIT. // // Lexicon: tools.ozone.server.getConfig // // 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 GetConfigOutput<'a> { #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub appview: std::option::Option< crate::tools_ozone::server::get_config::ServiceConfig<'a>, >, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub blob_divert: std::option::Option< crate::tools_ozone::server::get_config::ServiceConfig<'a>, >, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub chat: std::option::Option< crate::tools_ozone::server::get_config::ServiceConfig<'a>, >, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub pds: std::option::Option< crate::tools_ozone::server::get_config::ServiceConfig<'a>, >, /// The did of the verifier used for verification. #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub verifier_did: std::option::Option>, #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub viewer: std::option::Option< crate::tools_ozone::server::get_config::ViewerConfig<'a>, >, } /// XRPC request marker type #[derive( Debug, Clone, Copy, PartialEq, Eq, serde::Serialize, serde::Deserialize, jacquard_derive::IntoStatic )] pub struct GetConfig; /// Response type for ///tools.ozone.server.getConfig pub struct GetConfigResponse; impl jacquard_common::xrpc::XrpcResp for GetConfigResponse { const NSID: &'static str = "tools.ozone.server.getConfig"; const ENCODING: &'static str = "application/json"; type Output<'de> = GetConfigOutput<'de>; type Err<'de> = jacquard_common::xrpc::GenericError<'de>; } impl jacquard_common::xrpc::XrpcRequest for GetConfig { const NSID: &'static str = "tools.ozone.server.getConfig"; const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query; type Response = GetConfigResponse; } /// Endpoint type for ///tools.ozone.server.getConfig pub struct GetConfigRequest; impl jacquard_common::xrpc::XrpcEndpoint for GetConfigRequest { const PATH: &'static str = "/xrpc/tools.ozone.server.getConfig"; const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query; type Request<'de> = GetConfig; type Response = GetConfigResponse; } #[jacquard_derive::lexicon] #[derive( serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq, jacquard_derive::IntoStatic, Default )] #[serde(rename_all = "camelCase")] pub struct ServiceConfig<'a> { #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub url: std::option::Option>, } fn lexicon_doc_tools_ozone_server_getConfig() -> ::jacquard_lexicon::lexicon::LexiconDoc< 'static, > { ::jacquard_lexicon::lexicon::LexiconDoc { lexicon: ::jacquard_lexicon::lexicon::Lexicon::Lexicon1, id: ::jacquard_common::CowStr::new_static("tools.ozone.server.getConfig"), revision: None, description: None, defs: { let mut map = ::alloc::collections::BTreeMap::new(); map.insert( ::jacquard_common::smol_str::SmolStr::new_static("main"), ::jacquard_lexicon::lexicon::LexUserType::XrpcQuery(::jacquard_lexicon::lexicon::LexXrpcQuery { description: None, parameters: None, output: None, errors: None, }), ); map.insert( ::jacquard_common::smol_str::SmolStr::new_static("serviceConfig"), ::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject { description: None, required: None, nullable: None, properties: { #[allow(unused_mut)] let mut map = ::alloc::collections::BTreeMap::new(); map.insert( ::jacquard_common::smol_str::SmolStr::new_static("url"), ::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString { description: None, format: Some( ::jacquard_lexicon::lexicon::LexStringFormat::Uri, ), default: None, min_length: None, max_length: None, min_graphemes: None, max_graphemes: None, r#enum: None, r#const: None, known_values: None, }), ); map }, }), ); map.insert( ::jacquard_common::smol_str::SmolStr::new_static("viewerConfig"), ::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject { description: None, required: None, nullable: None, properties: { #[allow(unused_mut)] let mut map = ::alloc::collections::BTreeMap::new(); map.insert( ::jacquard_common::smol_str::SmolStr::new_static("role"), ::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString { description: None, format: None, default: None, min_length: None, max_length: None, min_graphemes: None, max_graphemes: None, r#enum: None, r#const: None, known_values: None, }), ); map }, }), ); map }, } } impl<'a> ::jacquard_lexicon::schema::LexiconSchema for ServiceConfig<'a> { fn nsid() -> &'static str { "tools.ozone.server.getConfig" } fn def_name() -> &'static str { "serviceConfig" } fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> { lexicon_doc_tools_ozone_server_getConfig() } fn validate( &self, ) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> { Ok(()) } } #[jacquard_derive::lexicon] #[derive( serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq, jacquard_derive::IntoStatic, Default )] #[serde(rename_all = "camelCase")] pub struct ViewerConfig<'a> { #[serde(skip_serializing_if = "std::option::Option::is_none")] #[serde(borrow)] pub role: std::option::Option>, } #[derive(Debug, Clone, PartialEq, Eq, Hash)] pub enum ViewerConfigRole<'a> { RoleAdmin, RoleModerator, RoleTriage, RoleVerifier, Other(jacquard_common::CowStr<'a>), } impl<'a> ViewerConfigRole<'a> { pub fn as_str(&self) -> &str { match self { Self::RoleAdmin => "tools.ozone.team.defs#roleAdmin", Self::RoleModerator => "tools.ozone.team.defs#roleModerator", Self::RoleTriage => "tools.ozone.team.defs#roleTriage", Self::RoleVerifier => "tools.ozone.team.defs#roleVerifier", Self::Other(s) => s.as_ref(), } } } impl<'a> From<&'a str> for ViewerConfigRole<'a> { fn from(s: &'a str) -> Self { match s { "tools.ozone.team.defs#roleAdmin" => Self::RoleAdmin, "tools.ozone.team.defs#roleModerator" => Self::RoleModerator, "tools.ozone.team.defs#roleTriage" => Self::RoleTriage, "tools.ozone.team.defs#roleVerifier" => Self::RoleVerifier, _ => Self::Other(jacquard_common::CowStr::from(s)), } } } impl<'a> From for ViewerConfigRole<'a> { fn from(s: String) -> Self { match s.as_str() { "tools.ozone.team.defs#roleAdmin" => Self::RoleAdmin, "tools.ozone.team.defs#roleModerator" => Self::RoleModerator, "tools.ozone.team.defs#roleTriage" => Self::RoleTriage, "tools.ozone.team.defs#roleVerifier" => Self::RoleVerifier, _ => Self::Other(jacquard_common::CowStr::from(s)), } } } impl<'a> core::fmt::Display for ViewerConfigRole<'a> { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { write!(f, "{}", self.as_str()) } } impl<'a> AsRef for ViewerConfigRole<'a> { fn as_ref(&self) -> &str { self.as_str() } } impl<'a> serde::Serialize for ViewerConfigRole<'a> { fn serialize(&self, serializer: S) -> Result where S: serde::Serializer, { serializer.serialize_str(self.as_str()) } } impl<'de, 'a> serde::Deserialize<'de> for ViewerConfigRole<'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 ViewerConfigRole<'a> { fn default() -> Self { Self::Other(Default::default()) } } impl jacquard_common::IntoStatic for ViewerConfigRole<'_> { type Output = ViewerConfigRole<'static>; fn into_static(self) -> Self::Output { match self { ViewerConfigRole::RoleAdmin => ViewerConfigRole::RoleAdmin, ViewerConfigRole::RoleModerator => ViewerConfigRole::RoleModerator, ViewerConfigRole::RoleTriage => ViewerConfigRole::RoleTriage, ViewerConfigRole::RoleVerifier => ViewerConfigRole::RoleVerifier, ViewerConfigRole::Other(v) => ViewerConfigRole::Other(v.into_static()), } } } impl<'a> ::jacquard_lexicon::schema::LexiconSchema for ViewerConfig<'a> { fn nsid() -> &'static str { "tools.ozone.server.getConfig" } fn def_name() -> &'static str { "viewerConfig" } fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> { lexicon_doc_tools_ozone_server_getConfig() } fn validate( &self, ) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> { Ok(()) } }