document_deps.rs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. use bytes::Bytes;
  2. use flowy_database::ConnectionPool;
  3. use flowy_document::{
  4. errors::{internal_error, FlowyError},
  5. DocumentCloudService, DocumentConfig, DocumentDatabase, DocumentManager, DocumentUser,
  6. };
  7. use flowy_http_model::ws_data::ClientRevisionWSData;
  8. use flowy_net::ClientServerConfiguration;
  9. use flowy_net::{
  10. http_server::document::DocumentCloudServiceImpl, local_server::LocalServer, ws::connection::FlowyWebSocketConnect,
  11. };
  12. use flowy_revision::{RevisionWebSocket, WSStateReceiver};
  13. use flowy_user::services::UserSession;
  14. use futures_core::future::BoxFuture;
  15. use lib_infra::future::BoxResultFuture;
  16. use lib_ws::{WSChannel, WSMessageReceiver, WebSocketRawMessage};
  17. use std::{convert::TryInto, path::Path, sync::Arc};
  18. pub struct DocumentDepsResolver();
  19. impl DocumentDepsResolver {
  20. pub fn resolve(
  21. local_server: Option<Arc<LocalServer>>,
  22. ws_conn: Arc<FlowyWebSocketConnect>,
  23. user_session: Arc<UserSession>,
  24. server_config: &ClientServerConfiguration,
  25. document_config: &DocumentConfig,
  26. ) -> Arc<DocumentManager> {
  27. let user = Arc::new(BlockUserImpl(user_session.clone()));
  28. let rev_web_socket = Arc::new(DocumentRevisionWebSocket(ws_conn.clone()));
  29. let cloud_service: Arc<dyn DocumentCloudService> = match local_server {
  30. None => Arc::new(DocumentCloudServiceImpl::new(server_config.clone())),
  31. Some(local_server) => local_server,
  32. };
  33. let database = Arc::new(DocumentDatabaseImpl(user_session));
  34. let manager = Arc::new(DocumentManager::new(
  35. cloud_service,
  36. user,
  37. database,
  38. rev_web_socket,
  39. document_config.clone(),
  40. ));
  41. let receiver = Arc::new(DocumentWSMessageReceiverImpl(manager.clone()));
  42. ws_conn.add_ws_message_receiver(receiver).unwrap();
  43. manager
  44. }
  45. }
  46. struct BlockUserImpl(Arc<UserSession>);
  47. impl DocumentUser for BlockUserImpl {
  48. fn user_dir(&self) -> Result<String, FlowyError> {
  49. let dir = self.0.user_dir().map_err(|e| FlowyError::unauthorized().context(e))?;
  50. let doc_dir = format!("{}/document", dir);
  51. if !Path::new(&doc_dir).exists() {
  52. std::fs::create_dir_all(&doc_dir)?;
  53. }
  54. Ok(doc_dir)
  55. }
  56. fn user_id(&self) -> Result<String, FlowyError> {
  57. self.0.user_id()
  58. }
  59. fn token(&self) -> Result<String, FlowyError> {
  60. self.0.token()
  61. }
  62. }
  63. struct DocumentDatabaseImpl(Arc<UserSession>);
  64. impl DocumentDatabase for DocumentDatabaseImpl {
  65. fn db_pool(&self) -> Result<Arc<ConnectionPool>, FlowyError> {
  66. self.0.db_pool()
  67. }
  68. }
  69. struct DocumentRevisionWebSocket(Arc<FlowyWebSocketConnect>);
  70. impl RevisionWebSocket for DocumentRevisionWebSocket {
  71. fn send(&self, data: ClientRevisionWSData) -> BoxResultFuture<(), FlowyError> {
  72. let bytes: Bytes = data.try_into().unwrap();
  73. let msg = WebSocketRawMessage {
  74. channel: WSChannel::Document,
  75. data: bytes.to_vec(),
  76. };
  77. let ws_conn = self.0.clone();
  78. Box::pin(async move {
  79. match ws_conn.web_socket().await? {
  80. None => {}
  81. Some(sender) => {
  82. sender.send(msg).map_err(internal_error)?;
  83. }
  84. }
  85. Ok(())
  86. })
  87. }
  88. fn subscribe_state_changed(&self) -> BoxFuture<WSStateReceiver> {
  89. let ws_conn = self.0.clone();
  90. Box::pin(async move { ws_conn.subscribe_websocket_state().await })
  91. }
  92. }
  93. struct DocumentWSMessageReceiverImpl(Arc<DocumentManager>);
  94. impl WSMessageReceiver for DocumentWSMessageReceiverImpl {
  95. fn source(&self) -> WSChannel {
  96. WSChannel::Document
  97. }
  98. fn receive_message(&self, msg: WebSocketRawMessage) {
  99. let handler = self.0.clone();
  100. tokio::spawn(async move {
  101. handler.receive_ws_data(Bytes::from(msg.data)).await;
  102. });
  103. }
  104. }