1dba94c9cb
* Combine prod and dev docker setups using build-arg - Fixes #2603 * Dont use cache for release build. * Adding 2FA / TOTP support. - Fixes #2363 * Changed name to totp_2fa for clarity. * Switch to sha256 for totp.
280 lines
7.7 KiB
Rust
280 lines
7.7 KiB
Rust
use crate::sensitive::Sensitive;
|
|
use lemmy_db_schema::{
|
|
newtypes::{CommentReplyId, CommunityId, LanguageId, PersonId, PersonMentionId},
|
|
CommentSortType,
|
|
SortType,
|
|
};
|
|
use lemmy_db_views::structs::{CommentView, PostView};
|
|
use lemmy_db_views_actor::structs::{
|
|
CommentReplyView,
|
|
CommunityModeratorView,
|
|
PersonMentionView,
|
|
PersonView,
|
|
};
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct Login {
|
|
pub username_or_email: Sensitive<String>,
|
|
pub password: Sensitive<String>,
|
|
pub totp_2fa_token: Option<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct Register {
|
|
pub username: String,
|
|
pub password: Sensitive<String>,
|
|
pub password_verify: Sensitive<String>,
|
|
pub show_nsfw: bool,
|
|
/// email is mandatory if email verification is enabled on the server
|
|
pub email: Option<Sensitive<String>>,
|
|
pub captcha_uuid: Option<String>,
|
|
pub captcha_answer: Option<String>,
|
|
pub honeypot: Option<String>,
|
|
/// An answer is mandatory if require application is enabled on the server
|
|
pub answer: Option<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetCaptcha {}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct GetCaptchaResponse {
|
|
pub ok: Option<CaptchaResponse>, // Will be None if captchas are disabled
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct CaptchaResponse {
|
|
pub png: String, // A Base64 encoded png
|
|
pub wav: String, // A Base64 encoded wav audio
|
|
pub uuid: String,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct SaveUserSettings {
|
|
pub show_nsfw: Option<bool>,
|
|
pub show_scores: Option<bool>,
|
|
pub theme: Option<String>,
|
|
pub default_sort_type: Option<i16>,
|
|
pub default_listing_type: Option<i16>,
|
|
pub interface_language: Option<String>,
|
|
pub avatar: Option<String>,
|
|
pub banner: Option<String>,
|
|
pub display_name: Option<String>,
|
|
pub email: Option<Sensitive<String>>,
|
|
pub bio: Option<String>,
|
|
pub matrix_user_id: Option<String>,
|
|
pub show_avatars: Option<bool>,
|
|
pub send_notifications_to_email: Option<bool>,
|
|
pub bot_account: Option<bool>,
|
|
pub show_bot_accounts: Option<bool>,
|
|
pub show_read_posts: Option<bool>,
|
|
pub show_new_post_notifs: Option<bool>,
|
|
pub discussion_languages: Option<Vec<LanguageId>>,
|
|
/// None leaves it as is, true will generate or regenerate it, false clears it out
|
|
pub generate_totp_2fa: Option<bool>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct ChangePassword {
|
|
pub new_password: Sensitive<String>,
|
|
pub new_password_verify: Sensitive<String>,
|
|
pub old_password: Sensitive<String>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct LoginResponse {
|
|
/// This is None in response to `Register` if email verification is enabled, or the server requires registration applications.
|
|
pub jwt: Option<Sensitive<String>>,
|
|
pub registration_created: bool,
|
|
pub verify_email_sent: bool,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetPersonDetails {
|
|
pub person_id: Option<PersonId>, // One of these two are required
|
|
/// Example: dessalines , or dessalines@xyz.tld
|
|
pub username: Option<String>,
|
|
pub sort: Option<SortType>,
|
|
pub page: Option<i64>,
|
|
pub limit: Option<i64>,
|
|
pub community_id: Option<CommunityId>,
|
|
pub saved_only: Option<bool>,
|
|
pub auth: Option<Sensitive<String>>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct GetPersonDetailsResponse {
|
|
pub person_view: PersonView,
|
|
pub comments: Vec<CommentView>,
|
|
pub posts: Vec<PostView>,
|
|
pub moderates: Vec<CommunityModeratorView>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetRepliesResponse {
|
|
pub replies: Vec<CommentReplyView>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct GetPersonMentionsResponse {
|
|
pub mentions: Vec<PersonMentionView>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct MarkAllAsRead {
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct AddAdmin {
|
|
pub person_id: PersonId,
|
|
pub added: bool,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct AddAdminResponse {
|
|
pub admins: Vec<PersonView>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct BanPerson {
|
|
pub person_id: PersonId,
|
|
pub ban: bool,
|
|
pub remove_data: Option<bool>,
|
|
pub reason: Option<String>,
|
|
pub expires: Option<i64>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetBannedPersons {
|
|
pub auth: String,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct BannedPersonsResponse {
|
|
pub banned: Vec<PersonView>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct BanPersonResponse {
|
|
pub person_view: PersonView,
|
|
pub banned: bool,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct BlockPerson {
|
|
pub person_id: PersonId,
|
|
pub block: bool,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct BlockPersonResponse {
|
|
pub person_view: PersonView,
|
|
pub blocked: bool,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetReplies {
|
|
pub sort: Option<CommentSortType>,
|
|
pub page: Option<i64>,
|
|
pub limit: Option<i64>,
|
|
pub unread_only: Option<bool>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetPersonMentions {
|
|
pub sort: Option<CommentSortType>,
|
|
pub page: Option<i64>,
|
|
pub limit: Option<i64>,
|
|
pub unread_only: Option<bool>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct MarkPersonMentionAsRead {
|
|
pub person_mention_id: PersonMentionId,
|
|
pub read: bool,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct PersonMentionResponse {
|
|
pub person_mention_view: PersonMentionView,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct MarkCommentReplyAsRead {
|
|
pub comment_reply_id: CommentReplyId,
|
|
pub read: bool,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct CommentReplyResponse {
|
|
pub comment_reply_view: CommentReplyView,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct DeleteAccount {
|
|
pub password: Sensitive<String>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct DeleteAccountResponse {}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct PasswordReset {
|
|
pub email: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct PasswordResetResponse {}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct PasswordChangeAfterReset {
|
|
pub token: Sensitive<String>,
|
|
pub password: Sensitive<String>,
|
|
pub password_verify: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetReportCount {
|
|
pub community_id: Option<CommunityId>,
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct GetReportCountResponse {
|
|
pub community_id: Option<CommunityId>,
|
|
pub comment_reports: i64,
|
|
pub post_reports: i64,
|
|
pub private_message_reports: Option<i64>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone, Default)]
|
|
pub struct GetUnreadCount {
|
|
pub auth: Sensitive<String>,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct GetUnreadCountResponse {
|
|
pub replies: i64,
|
|
pub mentions: i64,
|
|
pub private_messages: i64,
|
|
}
|
|
|
|
#[derive(Serialize, Deserialize, Clone, Default, Debug)]
|
|
pub struct VerifyEmail {
|
|
pub token: String,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize, Clone)]
|
|
pub struct VerifyEmailResponse {}
|