controller.rs 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. use bytes::Bytes;
  2. use chrono::Utc;
  3. use flowy_collaboration::client_document::default::{initial_delta, initial_read_me};
  4. use flowy_folder_data_model::user_default;
  5. use flowy_sync::RevisionWebSocket;
  6. use lazy_static::lazy_static;
  7. use flowy_collaboration::{client_folder::FolderPad, entities::ws_data::ServerRevisionWSData};
  8. use flowy_document::FlowyDocumentManager;
  9. use std::{collections::HashMap, convert::TryInto, fmt::Formatter, sync::Arc};
  10. use tokio::sync::RwLock as TokioRwLock;
  11. use crate::{
  12. dart_notification::{send_dart_notification, FolderNotification},
  13. entities::workspace::RepeatedWorkspace,
  14. errors::FlowyResult,
  15. event_map::{FolderCouldServiceV1, WorkspaceDatabase, WorkspaceUser},
  16. services::{
  17. folder_editor::FolderEditor, persistence::FolderPersistence, set_current_workspace, AppController,
  18. TrashController, ViewController, WorkspaceController,
  19. },
  20. };
  21. lazy_static! {
  22. static ref INIT_FOLDER_FLAG: TokioRwLock<HashMap<String, bool>> = TokioRwLock::new(HashMap::new());
  23. }
  24. const FOLDER_ID: &str = "folder";
  25. const FOLDER_ID_SPLIT: &str = ":";
  26. #[derive(Clone)]
  27. pub struct FolderId(String);
  28. impl FolderId {
  29. pub fn new(user_id: &str) -> Self {
  30. Self(format!("{}{}{}", user_id, FOLDER_ID_SPLIT, FOLDER_ID))
  31. }
  32. }
  33. impl std::fmt::Display for FolderId {
  34. fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
  35. f.write_str(FOLDER_ID)
  36. }
  37. }
  38. impl std::fmt::Debug for FolderId {
  39. fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
  40. f.write_str(FOLDER_ID)
  41. }
  42. }
  43. impl AsRef<str> for FolderId {
  44. fn as_ref(&self) -> &str {
  45. &self.0
  46. }
  47. }
  48. pub struct FolderManager {
  49. pub user: Arc<dyn WorkspaceUser>,
  50. pub(crate) cloud_service: Arc<dyn FolderCouldServiceV1>,
  51. pub(crate) persistence: Arc<FolderPersistence>,
  52. pub(crate) workspace_controller: Arc<WorkspaceController>,
  53. pub(crate) app_controller: Arc<AppController>,
  54. pub(crate) view_controller: Arc<ViewController>,
  55. pub(crate) trash_controller: Arc<TrashController>,
  56. web_socket: Arc<dyn RevisionWebSocket>,
  57. folder_editor: Arc<TokioRwLock<Option<Arc<FolderEditor>>>>,
  58. }
  59. impl FolderManager {
  60. pub async fn new(
  61. user: Arc<dyn WorkspaceUser>,
  62. cloud_service: Arc<dyn FolderCouldServiceV1>,
  63. database: Arc<dyn WorkspaceDatabase>,
  64. document_manager: Arc<FlowyDocumentManager>,
  65. web_socket: Arc<dyn RevisionWebSocket>,
  66. ) -> Self {
  67. if let Ok(user_id) = user.user_id() {
  68. // Reset the flag if the folder manager gets initialized, otherwise,
  69. // the folder_editor will not be initialized after flutter hot reload.
  70. INIT_FOLDER_FLAG.write().await.insert(user_id.to_owned(), false);
  71. }
  72. let folder_editor = Arc::new(TokioRwLock::new(None));
  73. let persistence = Arc::new(FolderPersistence::new(database.clone(), folder_editor.clone()));
  74. let trash_controller = Arc::new(TrashController::new(
  75. persistence.clone(),
  76. cloud_service.clone(),
  77. user.clone(),
  78. ));
  79. let view_controller = Arc::new(ViewController::new(
  80. user.clone(),
  81. persistence.clone(),
  82. cloud_service.clone(),
  83. trash_controller.clone(),
  84. document_manager,
  85. ));
  86. let app_controller = Arc::new(AppController::new(
  87. user.clone(),
  88. persistence.clone(),
  89. trash_controller.clone(),
  90. cloud_service.clone(),
  91. ));
  92. let workspace_controller = Arc::new(WorkspaceController::new(
  93. user.clone(),
  94. persistence.clone(),
  95. trash_controller.clone(),
  96. cloud_service.clone(),
  97. ));
  98. Self {
  99. user,
  100. cloud_service,
  101. persistence,
  102. workspace_controller,
  103. app_controller,
  104. view_controller,
  105. trash_controller,
  106. web_socket,
  107. folder_editor,
  108. }
  109. }
  110. // pub fn network_state_changed(&self, new_type: NetworkType) {
  111. // match new_type {
  112. // NetworkType::UnknownNetworkType => {},
  113. // NetworkType::Wifi => {},
  114. // NetworkType::Cell => {},
  115. // NetworkType::Ethernet => {},
  116. // }
  117. // }
  118. pub async fn did_receive_ws_data(&self, data: Bytes) {
  119. let result: Result<ServerRevisionWSData, protobuf::ProtobufError> = data.try_into();
  120. match result {
  121. Ok(data) => match self.folder_editor.read().await.clone() {
  122. None => {}
  123. Some(editor) => match editor.receive_ws_data(data).await {
  124. Ok(_) => {}
  125. Err(e) => tracing::error!("Folder receive data error: {:?}", e),
  126. },
  127. },
  128. Err(e) => {
  129. tracing::error!("Folder ws data parser failed: {:?}", e);
  130. }
  131. }
  132. }
  133. #[tracing::instrument(level = "trace", skip(self), err)]
  134. pub async fn initialize(&self, user_id: &str, token: &str) -> FlowyResult<()> {
  135. let mut write_guard = INIT_FOLDER_FLAG.write().await;
  136. if let Some(is_init) = write_guard.get(user_id) {
  137. if *is_init {
  138. return Ok(());
  139. }
  140. }
  141. tracing::debug!("Initialize folder editor");
  142. let folder_id = FolderId::new(user_id);
  143. let _ = self.persistence.initialize(user_id, &folder_id).await?;
  144. let pool = self.persistence.db_pool()?;
  145. let folder_editor = FolderEditor::new(user_id, &folder_id, token, pool, self.web_socket.clone()).await?;
  146. *self.folder_editor.write().await = Some(Arc::new(folder_editor));
  147. let _ = self.app_controller.initialize()?;
  148. let _ = self.view_controller.initialize()?;
  149. write_guard.insert(user_id.to_owned(), true);
  150. Ok(())
  151. }
  152. pub async fn initialize_with_new_user(&self, user_id: &str, token: &str) -> FlowyResult<()> {
  153. DefaultFolderBuilder::build(token, user_id, self.persistence.clone(), self.view_controller.clone()).await?;
  154. self.initialize(user_id, token).await
  155. }
  156. pub async fn clear(&self) {
  157. *self.folder_editor.write().await = None;
  158. }
  159. }
  160. struct DefaultFolderBuilder();
  161. impl DefaultFolderBuilder {
  162. async fn build(
  163. token: &str,
  164. user_id: &str,
  165. persistence: Arc<FolderPersistence>,
  166. view_controller: Arc<ViewController>,
  167. ) -> FlowyResult<()> {
  168. log::debug!("Create user default workspace");
  169. let time = Utc::now();
  170. let workspace = user_default::create_default_workspace(time);
  171. set_current_workspace(&workspace.id);
  172. for app in workspace.apps.iter() {
  173. for (index, view) in app.belongings.iter().enumerate() {
  174. let view_data = if index == 0 {
  175. initial_read_me().to_json()
  176. } else {
  177. initial_delta().to_json()
  178. };
  179. view_controller.set_latest_view(view);
  180. let _ = view_controller
  181. .create_view_document_content(&view.id, view_data)
  182. .await?;
  183. }
  184. }
  185. let folder = FolderPad::new(vec![workspace.clone()], vec![])?;
  186. let folder_id = FolderId::new(user_id);
  187. let _ = persistence.save_folder(user_id, &folder_id, folder).await?;
  188. let repeated_workspace = RepeatedWorkspace { items: vec![workspace] };
  189. send_dart_notification(token, FolderNotification::UserCreateWorkspace)
  190. .payload(repeated_workspace)
  191. .send();
  192. Ok(())
  193. }
  194. }
  195. #[cfg(feature = "flowy_unit_test")]
  196. impl FolderManager {
  197. pub async fn folder_editor(&self) -> Arc<FolderEditor> {
  198. self.folder_editor.read().await.clone().unwrap()
  199. }
  200. }