core.rs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. use backend_service::{
  2. configuration::{ClientServerConfiguration, HEADER_TOKEN},
  3. errors::ServerError,
  4. request::{HttpRequestBuilder, ResponseMiddleware},
  5. response::FlowyResponse,
  6. };
  7. use flowy_error::FlowyError;
  8. use flowy_folder_data_model::entities::{
  9. app::{App, AppId, CreateAppParams, UpdateAppParams},
  10. trash::{RepeatedTrash, RepeatedTrashId},
  11. view::{CreateViewParams, RepeatedViewId, UpdateViewParams, View, ViewId},
  12. workspace::{CreateWorkspaceParams, RepeatedWorkspace, UpdateWorkspaceParams, Workspace, WorkspaceId},
  13. };
  14. use flowy_folder::event_map::FolderCouldServiceV1;
  15. use lazy_static::lazy_static;
  16. use lib_infra::future::FutureResult;
  17. use std::sync::Arc;
  18. use tokio::sync::broadcast;
  19. pub struct FolderHttpCloudService {
  20. config: ClientServerConfiguration,
  21. }
  22. impl FolderHttpCloudService {
  23. pub fn new(config: ClientServerConfiguration) -> FolderHttpCloudService {
  24. Self { config }
  25. }
  26. }
  27. impl FolderCouldServiceV1 for FolderHttpCloudService {
  28. fn init(&self) {}
  29. fn create_workspace(&self, token: &str, params: CreateWorkspaceParams) -> FutureResult<Workspace, FlowyError> {
  30. let token = token.to_owned();
  31. let url = self.config.workspace_url();
  32. FutureResult::new(async move {
  33. let workspace = create_workspace_request(&token, params, &url).await?;
  34. Ok(workspace)
  35. })
  36. }
  37. fn read_workspace(&self, token: &str, params: WorkspaceId) -> FutureResult<RepeatedWorkspace, FlowyError> {
  38. let token = token.to_owned();
  39. let url = self.config.workspace_url();
  40. FutureResult::new(async move {
  41. let repeated_workspace = read_workspaces_request(&token, params, &url).await?;
  42. Ok(repeated_workspace)
  43. })
  44. }
  45. fn update_workspace(&self, token: &str, params: UpdateWorkspaceParams) -> FutureResult<(), FlowyError> {
  46. let token = token.to_owned();
  47. let url = self.config.workspace_url();
  48. FutureResult::new(async move {
  49. let _ = update_workspace_request(&token, params, &url).await?;
  50. Ok(())
  51. })
  52. }
  53. fn delete_workspace(&self, token: &str, params: WorkspaceId) -> FutureResult<(), FlowyError> {
  54. let token = token.to_owned();
  55. let url = self.config.workspace_url();
  56. FutureResult::new(async move {
  57. let _ = delete_workspace_request(&token, params, &url).await?;
  58. Ok(())
  59. })
  60. }
  61. fn create_view(&self, token: &str, params: CreateViewParams) -> FutureResult<View, FlowyError> {
  62. let token = token.to_owned();
  63. let url = self.config.view_url();
  64. FutureResult::new(async move {
  65. let view = create_view_request(&token, params, &url).await?;
  66. Ok(view)
  67. })
  68. }
  69. fn read_view(&self, token: &str, params: ViewId) -> FutureResult<Option<View>, FlowyError> {
  70. let token = token.to_owned();
  71. let url = self.config.view_url();
  72. FutureResult::new(async move {
  73. let view = read_view_request(&token, params, &url).await?;
  74. Ok(view)
  75. })
  76. }
  77. fn delete_view(&self, token: &str, params: RepeatedViewId) -> FutureResult<(), FlowyError> {
  78. let token = token.to_owned();
  79. let url = self.config.view_url();
  80. FutureResult::new(async move {
  81. let _ = delete_view_request(&token, params, &url).await?;
  82. Ok(())
  83. })
  84. }
  85. fn update_view(&self, token: &str, params: UpdateViewParams) -> FutureResult<(), FlowyError> {
  86. let token = token.to_owned();
  87. let url = self.config.view_url();
  88. FutureResult::new(async move {
  89. let _ = update_view_request(&token, params, &url).await?;
  90. Ok(())
  91. })
  92. }
  93. fn create_app(&self, token: &str, params: CreateAppParams) -> FutureResult<App, FlowyError> {
  94. let token = token.to_owned();
  95. let url = self.config.app_url();
  96. FutureResult::new(async move {
  97. let app = create_app_request(&token, params, &url).await?;
  98. Ok(app)
  99. })
  100. }
  101. fn read_app(&self, token: &str, params: AppId) -> FutureResult<Option<App>, FlowyError> {
  102. let token = token.to_owned();
  103. let url = self.config.app_url();
  104. FutureResult::new(async move {
  105. let app = read_app_request(&token, params, &url).await?;
  106. Ok(app)
  107. })
  108. }
  109. fn update_app(&self, token: &str, params: UpdateAppParams) -> FutureResult<(), FlowyError> {
  110. let token = token.to_owned();
  111. let url = self.config.app_url();
  112. FutureResult::new(async move {
  113. let _ = update_app_request(&token, params, &url).await?;
  114. Ok(())
  115. })
  116. }
  117. fn delete_app(&self, token: &str, params: AppId) -> FutureResult<(), FlowyError> {
  118. let token = token.to_owned();
  119. let url = self.config.app_url();
  120. FutureResult::new(async move {
  121. let _ = delete_app_request(&token, params, &url).await?;
  122. Ok(())
  123. })
  124. }
  125. fn create_trash(&self, token: &str, params: RepeatedTrashId) -> FutureResult<(), FlowyError> {
  126. let token = token.to_owned();
  127. let url = self.config.trash_url();
  128. FutureResult::new(async move {
  129. let _ = create_trash_request(&token, params, &url).await?;
  130. Ok(())
  131. })
  132. }
  133. fn delete_trash(&self, token: &str, params: RepeatedTrashId) -> FutureResult<(), FlowyError> {
  134. let token = token.to_owned();
  135. let url = self.config.trash_url();
  136. FutureResult::new(async move {
  137. let _ = delete_trash_request(&token, params, &url).await?;
  138. Ok(())
  139. })
  140. }
  141. fn read_trash(&self, token: &str) -> FutureResult<RepeatedTrash, FlowyError> {
  142. let token = token.to_owned();
  143. let url = self.config.trash_url();
  144. FutureResult::new(async move {
  145. let repeated_trash = read_trash_request(&token, &url).await?;
  146. Ok(repeated_trash)
  147. })
  148. }
  149. }
  150. fn request_builder() -> HttpRequestBuilder {
  151. HttpRequestBuilder::new().middleware(MIDDLEWARE.clone())
  152. }
  153. pub async fn create_workspace_request(
  154. token: &str,
  155. params: CreateWorkspaceParams,
  156. url: &str,
  157. ) -> Result<Workspace, ServerError> {
  158. let workspace = request_builder()
  159. .post(&url.to_owned())
  160. .header(HEADER_TOKEN, token)
  161. .protobuf(params)?
  162. .response()
  163. .await?;
  164. Ok(workspace)
  165. }
  166. pub async fn read_workspaces_request(
  167. token: &str,
  168. params: WorkspaceId,
  169. url: &str,
  170. ) -> Result<RepeatedWorkspace, ServerError> {
  171. let repeated_workspace = request_builder()
  172. .get(&url.to_owned())
  173. .header(HEADER_TOKEN, token)
  174. .protobuf(params)?
  175. .response::<RepeatedWorkspace>()
  176. .await?;
  177. Ok(repeated_workspace)
  178. }
  179. pub async fn update_workspace_request(
  180. token: &str,
  181. params: UpdateWorkspaceParams,
  182. url: &str,
  183. ) -> Result<(), ServerError> {
  184. let _ = request_builder()
  185. .patch(&url.to_owned())
  186. .header(HEADER_TOKEN, token)
  187. .protobuf(params)?
  188. .send()
  189. .await?;
  190. Ok(())
  191. }
  192. pub async fn delete_workspace_request(token: &str, params: WorkspaceId, url: &str) -> Result<(), ServerError> {
  193. let _ = request_builder()
  194. .delete(url)
  195. .header(HEADER_TOKEN, token)
  196. .protobuf(params)?
  197. .send()
  198. .await?;
  199. Ok(())
  200. }
  201. // App
  202. pub async fn create_app_request(token: &str, params: CreateAppParams, url: &str) -> Result<App, ServerError> {
  203. let app = request_builder()
  204. .post(&url.to_owned())
  205. .header(HEADER_TOKEN, token)
  206. .protobuf(params)?
  207. .response()
  208. .await?;
  209. Ok(app)
  210. }
  211. pub async fn read_app_request(token: &str, params: AppId, url: &str) -> Result<Option<App>, ServerError> {
  212. let app = request_builder()
  213. .get(&url.to_owned())
  214. .header(HEADER_TOKEN, token)
  215. .protobuf(params)?
  216. .option_response()
  217. .await?;
  218. Ok(app)
  219. }
  220. pub async fn update_app_request(token: &str, params: UpdateAppParams, url: &str) -> Result<(), ServerError> {
  221. let _ = request_builder()
  222. .patch(&url.to_owned())
  223. .header(HEADER_TOKEN, token)
  224. .protobuf(params)?
  225. .send()
  226. .await?;
  227. Ok(())
  228. }
  229. pub async fn delete_app_request(token: &str, params: AppId, url: &str) -> Result<(), ServerError> {
  230. let _ = request_builder()
  231. .delete(&url.to_owned())
  232. .header(HEADER_TOKEN, token)
  233. .protobuf(params)?
  234. .send()
  235. .await?;
  236. Ok(())
  237. }
  238. // View
  239. pub async fn create_view_request(token: &str, params: CreateViewParams, url: &str) -> Result<View, ServerError> {
  240. let view = request_builder()
  241. .post(&url.to_owned())
  242. .header(HEADER_TOKEN, token)
  243. .protobuf(params)?
  244. .response()
  245. .await?;
  246. Ok(view)
  247. }
  248. pub async fn read_view_request(token: &str, params: ViewId, url: &str) -> Result<Option<View>, ServerError> {
  249. let view = request_builder()
  250. .get(&url.to_owned())
  251. .header(HEADER_TOKEN, token)
  252. .protobuf(params)?
  253. .option_response()
  254. .await?;
  255. Ok(view)
  256. }
  257. pub async fn update_view_request(token: &str, params: UpdateViewParams, url: &str) -> Result<(), ServerError> {
  258. let _ = request_builder()
  259. .patch(&url.to_owned())
  260. .header(HEADER_TOKEN, token)
  261. .protobuf(params)?
  262. .send()
  263. .await?;
  264. Ok(())
  265. }
  266. pub async fn delete_view_request(token: &str, params: RepeatedViewId, url: &str) -> Result<(), ServerError> {
  267. let _ = request_builder()
  268. .delete(&url.to_owned())
  269. .header(HEADER_TOKEN, token)
  270. .protobuf(params)?
  271. .send()
  272. .await?;
  273. Ok(())
  274. }
  275. pub async fn create_trash_request(token: &str, params: RepeatedTrashId, url: &str) -> Result<(), ServerError> {
  276. let _ = request_builder()
  277. .post(&url.to_owned())
  278. .header(HEADER_TOKEN, token)
  279. .protobuf(params)?
  280. .send()
  281. .await?;
  282. Ok(())
  283. }
  284. pub async fn delete_trash_request(token: &str, params: RepeatedTrashId, url: &str) -> Result<(), ServerError> {
  285. let _ = request_builder()
  286. .delete(&url.to_owned())
  287. .header(HEADER_TOKEN, token)
  288. .protobuf(params)?
  289. .send()
  290. .await?;
  291. Ok(())
  292. }
  293. pub async fn read_trash_request(token: &str, url: &str) -> Result<RepeatedTrash, ServerError> {
  294. let repeated_trash = request_builder()
  295. .get(&url.to_owned())
  296. .header(HEADER_TOKEN, token)
  297. .response::<RepeatedTrash>()
  298. .await?;
  299. Ok(repeated_trash)
  300. }
  301. lazy_static! {
  302. static ref MIDDLEWARE: Arc<CoreResponseMiddleware> = Arc::new(CoreResponseMiddleware::new());
  303. }
  304. pub struct CoreResponseMiddleware {
  305. invalid_token_sender: broadcast::Sender<String>,
  306. }
  307. impl CoreResponseMiddleware {
  308. fn new() -> Self {
  309. let (sender, _) = broadcast::channel(10);
  310. CoreResponseMiddleware {
  311. invalid_token_sender: sender,
  312. }
  313. }
  314. #[allow(dead_code)]
  315. fn invalid_token_subscribe(&self) -> broadcast::Receiver<String> {
  316. self.invalid_token_sender.subscribe()
  317. }
  318. }
  319. impl ResponseMiddleware for CoreResponseMiddleware {
  320. fn receive_response(&self, token: &Option<String>, response: &FlowyResponse) {
  321. if let Some(error) = &response.error {
  322. if error.is_unauthorized() {
  323. tracing::error!("user is unauthorized");
  324. match token {
  325. None => {}
  326. Some(token) => match self.invalid_token_sender.send(token.clone()) {
  327. Ok(_) => {}
  328. Err(e) => tracing::error!("{:?}", e),
  329. },
  330. }
  331. }
  332. }
  333. }
  334. }