123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- use crate::request::HttpRequestBuilder;
- use flowy_client_network_config::{ClientServerConfiguration, HEADER_TOKEN};
- use flowy_error::FlowyError;
- use flowy_user::entities::UserProfilePB;
- use flowy_user::event_map::UserCloudService;
- use lib_infra::future::FutureResult;
- use user_model::*;
- pub struct UserHttpCloudService {
- config: ClientServerConfiguration,
- }
- impl UserHttpCloudService {
- pub fn new(config: &ClientServerConfiguration) -> Self {
- Self {
- config: config.clone(),
- }
- }
- }
- impl UserCloudService for UserHttpCloudService {
- fn sign_up(&self, params: SignUpParams) -> FutureResult<SignUpResponse, FlowyError> {
- let url = self.config.sign_up_url();
- FutureResult::new(async move {
- let resp = user_sign_up_request(params, &url).await?;
- Ok(resp)
- })
- }
- fn sign_in(&self, params: SignInParams) -> FutureResult<SignInResponse, FlowyError> {
- let url = self.config.sign_in_url();
- FutureResult::new(async move {
- let resp = user_sign_in_request(params, &url).await?;
- Ok(resp)
- })
- }
- fn sign_out(&self, token: &str) -> FutureResult<(), FlowyError> {
- let token = token.to_owned();
- let url = self.config.sign_out_url();
- FutureResult::new(async move {
- let _ = user_sign_out_request(&token, &url).await;
- Ok(())
- })
- }
- fn update_user(
- &self,
- token: &str,
- params: UpdateUserProfileParams,
- ) -> FutureResult<(), FlowyError> {
- let token = token.to_owned();
- let url = self.config.user_profile_url();
- FutureResult::new(async move {
- update_user_profile_request(&token, params, &url).await?;
- Ok(())
- })
- }
- fn get_user(&self, token: &str) -> FutureResult<UserProfilePB, FlowyError> {
- let token = token.to_owned();
- let url = self.config.user_profile_url();
- FutureResult::new(async move {
- let profile = get_user_profile_request(&token, &url).await?;
- Ok(profile)
- })
- }
- fn ws_addr(&self) -> String {
- self.config.ws_addr()
- }
- }
- pub async fn user_sign_up_request(
- params: SignUpParams,
- url: &str,
- ) -> Result<SignUpResponse, FlowyError> {
- let response = request_builder()
- .post(url)
- .json(params)?
- .json_response()
- .await?;
- Ok(response)
- }
- pub async fn user_sign_in_request(
- params: SignInParams,
- url: &str,
- ) -> Result<SignInResponse, FlowyError> {
- let response = request_builder()
- .post(url)
- .json(params)?
- .json_response()
- .await?;
- Ok(response)
- }
- pub async fn user_sign_out_request(token: &str, url: &str) -> Result<(), FlowyError> {
- request_builder()
- .delete(url)
- .header(HEADER_TOKEN, token)
- .send()
- .await?;
- Ok(())
- }
- pub async fn get_user_profile_request(token: &str, url: &str) -> Result<UserProfilePB, FlowyError> {
- let user_profile = request_builder()
- .get(url)
- .header(HEADER_TOKEN, token)
- .response()
- .await?;
- Ok(user_profile)
- }
- pub async fn update_user_profile_request(
- token: &str,
- params: UpdateUserProfileParams,
- url: &str,
- ) -> Result<(), FlowyError> {
- request_builder()
- .patch(url)
- .header(HEADER_TOKEN, token)
- .json(params)?
- .send()
- .await?;
- Ok(())
- }
- fn request_builder() -> HttpRequestBuilder {
- HttpRequestBuilder::new()
- }
|