use lemmy_db_schema::newtypes::OAuthProviderId; use serde::{Deserialize, Serialize}; use serde_with::skip_serializing_none; #[cfg(feature = "full")] use ts_rs::TS; use url::Url; #[skip_serializing_none] #[derive(Debug, Serialize, Deserialize, Clone)] #[cfg_attr(feature = "full", derive(TS))] #[cfg_attr(feature = "full", ts(export))] /// Create an external auth method. pub struct CreateOAuthProvider { pub display_name: String, pub issuer: String, pub authorization_endpoint: String, pub token_endpoint: String, pub userinfo_endpoint: String, pub id_claim: String, pub client_id: String, pub client_secret: String, pub scopes: String, #[cfg_attr(feature = "full", ts(optional))] pub auto_verify_email: Option, #[cfg_attr(feature = "full", ts(optional))] pub account_linking_enabled: Option, #[cfg_attr(feature = "full", ts(optional))] pub enabled: Option, } #[skip_serializing_none] #[derive(Debug, Serialize, Deserialize, Clone)] #[cfg_attr(feature = "full", derive(TS))] #[cfg_attr(feature = "full", ts(export))] /// Edit an external auth method. pub struct EditOAuthProvider { pub id: OAuthProviderId, #[cfg_attr(feature = "full", ts(optional))] pub display_name: Option, #[cfg_attr(feature = "full", ts(optional))] pub authorization_endpoint: Option, #[cfg_attr(feature = "full", ts(optional))] pub token_endpoint: Option, #[cfg_attr(feature = "full", ts(optional))] pub userinfo_endpoint: Option, #[cfg_attr(feature = "full", ts(optional))] pub id_claim: Option, #[cfg_attr(feature = "full", ts(optional))] pub client_secret: Option, #[cfg_attr(feature = "full", ts(optional))] pub scopes: Option, #[cfg_attr(feature = "full", ts(optional))] pub auto_verify_email: Option, #[cfg_attr(feature = "full", ts(optional))] pub account_linking_enabled: Option, #[cfg_attr(feature = "full", ts(optional))] pub enabled: Option, } #[derive(Debug, Serialize, Deserialize, Clone, Default)] #[cfg_attr(feature = "full", derive(TS))] #[cfg_attr(feature = "full", ts(export))] /// Delete an external auth method. pub struct DeleteOAuthProvider { pub id: OAuthProviderId, } #[skip_serializing_none] #[derive(Debug, Serialize, Deserialize, Clone)] #[cfg_attr(feature = "full", derive(TS))] #[cfg_attr(feature = "full", ts(export))] /// Logging in with an OAuth 2.0 authorization pub struct AuthenticateWithOauth { pub code: String, pub oauth_provider_id: OAuthProviderId, pub redirect_uri: Url, #[cfg_attr(feature = "full", ts(optional))] pub show_nsfw: Option, /// Username is mandatory at registration time #[cfg_attr(feature = "full", ts(optional))] pub username: Option, /// An answer is mandatory if require application is enabled on the server #[cfg_attr(feature = "full", ts(optional))] pub answer: Option, }