2023-04-04 08:41:16 +08:00
|
|
|
use crate::entities::*;
|
|
|
|
use crate::services::UserSession;
|
|
|
|
use flowy_error::FlowyError;
|
2023-01-31 08:28:31 +08:00
|
|
|
use flowy_sqlite::kv::KV;
|
2021-11-19 14:38:11 +08:00
|
|
|
use lib_dispatch::prelude::*;
|
2021-07-14 21:12:52 +08:00
|
|
|
use std::{convert::TryInto, sync::Arc};
|
2023-04-04 08:41:16 +08:00
|
|
|
use user_model::{SignInParams, SignUpParams, UpdateUserProfileParams};
|
|
|
|
|
|
|
|
// tracing instrument 👉🏻 https://docs.rs/tracing/0.1.26/tracing/attr.instrument.html
|
|
|
|
#[tracing::instrument(level = "debug", name = "sign_in", skip(data, session), fields(email = %data.email), err)]
|
|
|
|
pub async fn sign_in(
|
|
|
|
data: AFPluginData<SignInPayloadPB>,
|
|
|
|
session: AFPluginState<Arc<UserSession>>,
|
|
|
|
) -> DataResult<UserProfilePB, FlowyError> {
|
|
|
|
let params: SignInParams = data.into_inner().try_into()?;
|
|
|
|
let user_profile: UserProfilePB = session.sign_in(params).await?.into();
|
|
|
|
data_result_ok(user_profile)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(
|
|
|
|
level = "debug",
|
|
|
|
name = "sign_up",
|
|
|
|
skip(data, session),
|
|
|
|
fields(
|
|
|
|
email = %data.email,
|
|
|
|
name = %data.name,
|
|
|
|
),
|
|
|
|
err
|
|
|
|
)]
|
|
|
|
pub async fn sign_up(
|
|
|
|
data: AFPluginData<SignUpPayloadPB>,
|
|
|
|
session: AFPluginState<Arc<UserSession>>,
|
|
|
|
) -> DataResult<UserProfilePB, FlowyError> {
|
|
|
|
let params: SignUpParams = data.into_inner().try_into()?;
|
|
|
|
let user_profile: UserProfilePB = session.sign_up(params).await?.into();
|
|
|
|
|
|
|
|
data_result_ok(user_profile)
|
|
|
|
}
|
2021-07-14 21:12:52 +08:00
|
|
|
|
2022-04-12 11:13:35 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(session))]
|
2022-12-01 08:35:50 +08:00
|
|
|
pub async fn init_user_handler(session: AFPluginState<Arc<UserSession>>) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
session.init_user().await?;
|
|
|
|
Ok(())
|
2021-09-25 21:47:02 +08:00
|
|
|
}
|
|
|
|
|
2022-04-12 11:13:35 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(session))]
|
2023-02-13 09:29:49 +08:00
|
|
|
pub async fn check_user_handler(
|
|
|
|
session: AFPluginState<Arc<UserSession>>,
|
|
|
|
) -> DataResult<UserProfilePB, FlowyError> {
|
|
|
|
let user_profile: UserProfilePB = session.check_user().await?.into();
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(user_profile)
|
2021-09-17 19:03:46 +08:00
|
|
|
}
|
|
|
|
|
2022-04-12 11:13:35 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(session))]
|
2022-12-01 08:35:50 +08:00
|
|
|
pub async fn get_user_profile_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
session: AFPluginState<Arc<UserSession>>,
|
2022-12-01 08:35:50 +08:00
|
|
|
) -> DataResult<UserProfilePB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let user_profile: UserProfilePB = session.get_user_profile().await?.into();
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(user_profile)
|
2021-07-14 21:12:52 +08:00
|
|
|
}
|
|
|
|
|
2022-04-12 11:13:35 +08:00
|
|
|
#[tracing::instrument(level = "debug", name = "sign_out", skip(session))]
|
2022-12-01 08:35:50 +08:00
|
|
|
pub async fn sign_out(session: AFPluginState<Arc<UserSession>>) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
session.sign_out().await?;
|
|
|
|
Ok(())
|
2021-07-14 21:12:52 +08:00
|
|
|
}
|
|
|
|
|
2022-07-03 16:52:06 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, session))]
|
|
|
|
pub async fn update_user_profile_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<UpdateUserProfilePayloadPB>,
|
|
|
|
session: AFPluginState<Arc<UserSession>>,
|
2021-12-14 18:04:51 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: UpdateUserProfileParams = data.into_inner().try_into()?;
|
|
|
|
session.update_user_profile(params).await?;
|
|
|
|
Ok(())
|
2021-07-14 21:12:52 +08:00
|
|
|
}
|
2022-01-28 10:56:55 +08:00
|
|
|
|
|
|
|
const APPEARANCE_SETTING_CACHE_KEY: &str = "appearance_settings";
|
|
|
|
|
2022-04-12 11:13:35 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(data), err)]
|
2023-02-13 09:29:49 +08:00
|
|
|
pub async fn set_appearance_setting(
|
|
|
|
data: AFPluginData<AppearanceSettingsPB>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let mut setting = data.into_inner();
|
|
|
|
if setting.theme.is_empty() {
|
|
|
|
setting.theme = APPEARANCE_DEFAULT_THEME.to_string();
|
|
|
|
}
|
2022-01-28 10:56:55 +08:00
|
|
|
|
2023-02-13 09:29:49 +08:00
|
|
|
let s = serde_json::to_string(&setting)?;
|
|
|
|
KV::set_str(APPEARANCE_SETTING_CACHE_KEY, s);
|
|
|
|
Ok(())
|
2022-01-28 10:56:55 +08:00
|
|
|
}
|
|
|
|
|
2022-10-26 11:09:51 +08:00
|
|
|
#[tracing::instrument(level = "debug", err)]
|
2022-07-19 14:40:56 +08:00
|
|
|
pub async fn get_appearance_setting() -> DataResult<AppearanceSettingsPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
match KV::get_str(APPEARANCE_SETTING_CACHE_KEY) {
|
2023-02-26 16:27:17 +08:00
|
|
|
None => data_result_ok(AppearanceSettingsPB::default()),
|
2023-02-13 09:29:49 +08:00
|
|
|
Some(s) => {
|
|
|
|
let setting = match serde_json::from_str(&s) {
|
|
|
|
Ok(setting) => setting,
|
|
|
|
Err(e) => {
|
|
|
|
tracing::error!(
|
|
|
|
"Deserialize AppearanceSettings failed: {:?}, fallback to default",
|
|
|
|
e
|
|
|
|
);
|
|
|
|
AppearanceSettingsPB::default()
|
|
|
|
},
|
|
|
|
};
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(setting)
|
2023-02-13 09:29:49 +08:00
|
|
|
},
|
|
|
|
}
|
2022-01-28 10:56:55 +08:00
|
|
|
}
|
2022-11-11 17:24:10 +08:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip_all, err)]
|
2023-02-13 09:29:49 +08:00
|
|
|
pub async fn get_user_setting(
|
|
|
|
session: AFPluginState<Arc<UserSession>>,
|
|
|
|
) -> DataResult<UserSettingPB, FlowyError> {
|
|
|
|
let user_setting = session.user_setting()?;
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(user_setting)
|
2022-11-11 17:24:10 +08:00
|
|
|
}
|