2024-09-18 12:52:33 +00:00
|
|
|
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;
|
|
|
|
|
|
|
|
#[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,
|
2024-09-26 08:24:51 +00:00
|
|
|
pub auto_verify_email: Option<bool>,
|
|
|
|
pub account_linking_enabled: Option<bool>,
|
|
|
|
pub enabled: Option<bool>,
|
2024-09-18 12:52:33 +00:00
|
|
|
}
|
|
|
|
|
2024-09-26 08:24:51 +00:00
|
|
|
#[skip_serializing_none]
|
2024-09-18 12:52:33 +00:00
|
|
|
#[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,
|
|
|
|
pub display_name: Option<String>,
|
|
|
|
pub authorization_endpoint: Option<String>,
|
|
|
|
pub token_endpoint: Option<String>,
|
|
|
|
pub userinfo_endpoint: Option<String>,
|
|
|
|
pub id_claim: Option<String>,
|
|
|
|
pub client_secret: Option<String>,
|
|
|
|
pub scopes: Option<String>,
|
|
|
|
pub auto_verify_email: Option<bool>,
|
|
|
|
pub account_linking_enabled: Option<bool>,
|
|
|
|
pub enabled: Option<bool>,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[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,
|
|
|
|
#[cfg_attr(feature = "full", ts(type = "string"))]
|
|
|
|
pub oauth_provider_id: OAuthProviderId,
|
|
|
|
#[cfg_attr(feature = "full", ts(type = "string"))]
|
|
|
|
pub redirect_uri: Url,
|
|
|
|
pub show_nsfw: Option<bool>,
|
|
|
|
/// Username is mandatory at registration time
|
|
|
|
pub username: Option<String>,
|
|
|
|
/// An answer is mandatory if require application is enabled on the server
|
|
|
|
pub answer: Option<String>,
|
|
|
|
}
|