1
0
mirror of https://gitlab.com/comunic/comunicapiv3 synced 2025-01-05 18:38:51 +00:00
comunicapiv3/src/data/user.rs

168 lines
4.6 KiB
Rust

use std::hash::{Hash, Hasher};
use crate::utils::user_data_utils::user_data_url;
///! User information
///!
///! @author Pierre Hubert
#[derive(Clone, PartialEq, Eq, Debug)]
pub struct UserID(u64);
impl UserID {
/// Initialize a new user ID object
pub fn new(id: u64) -> UserID {
UserID(id)
}
/// Create a new invalid user id
pub fn invalid() -> UserID {
UserID(0)
}
/// Get the current ID stored in this structure
pub fn id(&self) -> u64 {
self.0
}
/// Check if the ID currently stored in this structure is valid or not
pub fn is_valid(&self) -> bool {
self.0 > 0
}
/// Turn this `UserID` object as an instance. An invalid user id will become `None` variant
pub fn as_option(&self) -> Option<UserID> {
match self.is_valid() {
true => Some(self.clone()),
false => None,
}
}
}
impl Hash for UserID {
fn hash<H: Hasher>(&self, state: &mut H) {
self.0.hash(state)
}
}
impl PartialEq<&UserID> for UserID {
fn eq(&self, other: &&UserID) -> bool {
self.0 == other.0
}
}
impl PartialEq<UserID> for &UserID {
fn eq(&self, other: &UserID) -> bool {
self.0 == other.0
}
}
#[derive(Debug, PartialEq)]
pub enum UserPageStatus {
OPEN,
PUBLIC,
PRIVATE,
}
#[derive(Debug, PartialEq)]
#[allow(non_camel_case_types)]
pub enum AccountImageVisibility {
FRIENDS,
COMUNIC_USERS,
EVERYONE,
}
impl AccountImageVisibility {
pub fn to_api(&self) -> String {
match self {
AccountImageVisibility::FRIENDS => "friends".to_string(),
AccountImageVisibility::COMUNIC_USERS => "public".to_string(),
AccountImageVisibility::EVERYONE => "open".to_string(),
}
}
pub fn from_api(s: &str) -> Self {
match s {
"friends" => AccountImageVisibility::FRIENDS,
"public" => AccountImageVisibility::COMUNIC_USERS,
"open" | _ => AccountImageVisibility::EVERYONE,
}
}
pub fn to_db(&self) -> String {
match self {
AccountImageVisibility::FRIENDS => "friends".to_string(),
AccountImageVisibility::COMUNIC_USERS => "comunic_users".to_string(),
AccountImageVisibility::EVERYONE => "everyone".to_string(),
}
}
}
#[derive(Debug)]
pub struct User {
pub id: UserID,
pub email: String,
pub password: String,
pub first_name: String,
pub last_name: String,
pub last_activity: u64,
pub status: UserPageStatus,
pub virtual_directory: Option<String>,
pub account_image_path: Option<String>,
pub account_image_visibility: AccountImageVisibility,
pub public_friends_list: bool,
pub personal_website: Option<String>,
pub public_note: Option<String>,
pub block_comments_on_his_page: bool,
pub allow_posts_from_friends: bool,
pub account_creation_time: u64,
pub allow_mails: bool,
pub lang: String,
pub security_question_1: Option<String>,
pub security_answer_1: Option<String>,
pub security_question_2: Option<String>,
pub security_answer_2: Option<String>,
/// Automatically delete the account after a period of inactivity. 0 = feature disabled
pub delete_account_after: Option<u64>,
pub delete_notifications_after: Option<u64>,
pub delete_comments_after: Option<u64>,
pub delete_posts_after: Option<u64>,
pub delete_conversation_messages_after: Option<u64>,
pub delete_likes_after: Option<u64>,
}
impl User {
/// Check if user's page is public
pub fn is_page_public(&self) -> bool {
!matches!(self.status, UserPageStatus::PRIVATE)
}
/// Check if user's page is open
pub fn is_page_open(&self) -> bool {
matches!(self.status, UserPageStatus::OPEN)
}
/// Get the URL pointing to the default account image
pub fn default_account_image_url() -> String {
user_data_url(crate::constants::DEFAULT_ACCOUNT_IMAGE)
}
/// Get the URL pointing to the error account image, when the user is not allowed to see user
/// account image
pub fn error_account_image_url() -> String {
user_data_url(crate::constants::ERROR_ACCOUNT_IMAGE)
}
/// Check if this user has an account image or not
pub fn has_account_image(&self) -> bool {
self.account_image_path.is_some()
}
/// Check out whether security questions have been defined for this user or not
pub fn has_security_questions(&self) -> bool {
self.security_question_1.is_some() &&
self.security_answer_1.is_some() &&
self.security_question_2.is_some() &&
self.security_answer_2.is_some()
}
}