199 lines
6.8 KiB
Rust
Raw Normal View History

2022-03-05 22:30:42 +08:00
use async_trait::async_trait;
2022-01-14 20:52:03 +08:00
use bytes::Bytes;
use flowy_block::BlockManager;
2022-03-05 22:30:42 +08:00
use flowy_collaboration::entities::revision::RepeatedRevision;
2022-01-15 11:20:28 +08:00
use flowy_collaboration::entities::ws_data::ClientRevisionWSData;
use flowy_database::ConnectionPool;
2022-03-05 22:30:42 +08:00
use flowy_folder::manager::{DataProcessorMap, ViewDataProcessor};
use flowy_folder::prelude::{FlowyResult, ViewDataType};
use flowy_folder::{
2022-01-14 20:52:03 +08:00
errors::{internal_error, FlowyError},
2022-01-30 10:33:21 +08:00
event_map::{FolderCouldServiceV1, WorkspaceDatabase, WorkspaceUser},
manager::FolderManager,
2022-01-10 23:45:59 +08:00
};
2022-03-05 22:30:42 +08:00
use flowy_grid::manager::GridManager;
use flowy_net::ClientServerConfiguration;
2022-01-14 20:52:03 +08:00
use flowy_net::{
http_server::folder::FolderHttpCloudService, local_server::LocalServer, ws::connection::FlowyWebSocketConnect,
2022-01-14 20:52:03 +08:00
};
use flowy_sync::{RevisionWebSocket, WSStateReceiver};
2022-01-11 13:34:45 +08:00
use flowy_user::services::UserSession;
2022-01-24 16:27:40 +08:00
use futures_core::future::BoxFuture;
use lib_infra::future::BoxResultFuture;
2022-01-22 18:48:43 +08:00
use lib_ws::{WSChannel, WSMessageReceiver, WebSocketRawMessage};
2022-03-05 22:30:42 +08:00
use std::collections::HashMap;
2022-01-14 20:52:03 +08:00
use std::{convert::TryInto, sync::Arc};
2022-01-10 23:45:59 +08:00
2022-01-20 23:51:11 +08:00
pub struct FolderDepsResolver();
impl FolderDepsResolver {
2022-01-23 22:33:47 +08:00
pub async fn resolve(
2022-01-13 10:53:30 +08:00
local_server: Option<Arc<LocalServer>>,
2022-01-10 23:45:59 +08:00
user_session: Arc<UserSession>,
server_config: &ClientServerConfiguration,
2022-03-05 22:30:42 +08:00
ws_conn: &Arc<FlowyWebSocketConnect>,
block_manager: &Arc<BlockManager>,
2022-03-05 22:30:42 +08:00
grid_manager: &Arc<GridManager>,
2022-01-14 20:52:03 +08:00
) -> Arc<FolderManager> {
2022-01-10 23:45:59 +08:00
let user: Arc<dyn WorkspaceUser> = Arc::new(WorkspaceUserImpl(user_session.clone()));
let database: Arc<dyn WorkspaceDatabase> = Arc::new(WorkspaceDatabaseImpl(user_session));
2022-02-25 22:27:44 +08:00
let web_socket = Arc::new(FolderWebSocket(ws_conn.clone()));
2022-01-17 11:55:36 +08:00
let cloud_service: Arc<dyn FolderCouldServiceV1> = match local_server {
None => Arc::new(FolderHttpCloudService::new(server_config.clone())),
2022-01-13 10:53:30 +08:00
Some(local_server) => local_server,
};
2022-01-14 20:52:03 +08:00
2022-03-05 22:30:42 +08:00
let view_data_processor = make_view_data_processor(block_manager.clone(), grid_manager.clone());
2022-01-24 16:27:40 +08:00
let folder_manager = Arc::new(
2022-03-05 22:30:42 +08:00
FolderManager::new(
user.clone(),
cloud_service,
database,
view_data_processor,
block_manager.clone(),
web_socket,
)
.await,
2022-01-24 16:27:40 +08:00
);
if let (Ok(user_id), Ok(token)) = (user.user_id(), user.token()) {
match folder_manager.initialize(&user_id, &token).await {
2022-01-24 17:35:58 +08:00
Ok(_) => {}
2022-01-24 16:27:40 +08:00
Err(e) => tracing::error!("Initialize folder manager failed: {}", e),
}
}
2022-01-20 23:51:11 +08:00
2022-01-14 20:52:03 +08:00
let receiver = Arc::new(FolderWSMessageReceiverImpl(folder_manager.clone()));
ws_conn.add_ws_message_receiver(receiver).unwrap();
folder_manager
2022-01-10 23:45:59 +08:00
}
}
2022-03-05 22:30:42 +08:00
fn make_view_data_processor(block_manager: Arc<BlockManager>, grid_manager: Arc<GridManager>) -> DataProcessorMap {
let mut map: HashMap<ViewDataType, Arc<dyn ViewDataProcessor + Send + Sync>> = HashMap::new();
let block_data_impl = BlockManagerViewDataImpl(block_manager);
map.insert(block_data_impl.data_type(), Arc::new(block_data_impl));
let grid_data_impl = GridManagerViewDataImpl(grid_manager);
map.insert(grid_data_impl.data_type(), Arc::new(grid_data_impl));
Arc::new(map)
}
2022-01-10 23:45:59 +08:00
struct WorkspaceDatabaseImpl(Arc<UserSession>);
impl WorkspaceDatabase for WorkspaceDatabaseImpl {
fn db_pool(&self) -> Result<Arc<ConnectionPool>, FlowyError> {
self.0.db_pool().map_err(|e| FlowyError::internal().context(e))
}
}
struct WorkspaceUserImpl(Arc<UserSession>);
impl WorkspaceUser for WorkspaceUserImpl {
2022-01-24 17:35:58 +08:00
fn user_id(&self) -> Result<String, FlowyError> {
self.0.user_id().map_err(|e| FlowyError::internal().context(e))
}
2022-01-10 23:45:59 +08:00
2022-01-24 17:35:58 +08:00
fn token(&self) -> Result<String, FlowyError> {
self.0.token().map_err(|e| FlowyError::internal().context(e))
}
2022-01-10 23:45:59 +08:00
}
2022-01-14 20:52:03 +08:00
2022-02-25 22:27:44 +08:00
struct FolderWebSocket(Arc<FlowyWebSocketConnect>);
impl RevisionWebSocket for FolderWebSocket {
2022-01-24 16:27:40 +08:00
fn send(&self, data: ClientRevisionWSData) -> BoxResultFuture<(), FlowyError> {
2022-01-14 20:52:03 +08:00
let bytes: Bytes = data.try_into().unwrap();
let msg = WebSocketRawMessage {
2022-01-22 18:48:43 +08:00
channel: WSChannel::Folder,
2022-01-14 20:52:03 +08:00
data: bytes.to_vec(),
};
2022-01-24 16:27:40 +08:00
let ws_conn = self.0.clone();
Box::pin(async move {
match ws_conn.web_socket().await? {
2022-01-24 17:35:58 +08:00
None => {}
2022-01-24 16:27:40 +08:00
Some(sender) => {
sender.send(msg).map_err(internal_error)?;
2022-01-24 17:35:58 +08:00
}
2022-01-24 16:27:40 +08:00
}
Ok(())
})
2022-01-14 20:52:03 +08:00
}
2022-01-24 16:27:40 +08:00
fn subscribe_state_changed(&self) -> BoxFuture<WSStateReceiver> {
let ws_conn = self.0.clone();
Box::pin(async move { ws_conn.subscribe_websocket_state().await })
}
2022-01-14 20:52:03 +08:00
}
struct FolderWSMessageReceiverImpl(Arc<FolderManager>);
impl WSMessageReceiver for FolderWSMessageReceiverImpl {
2022-01-24 17:35:58 +08:00
fn source(&self) -> WSChannel {
WSChannel::Folder
}
2022-01-14 20:52:03 +08:00
fn receive_message(&self, msg: WebSocketRawMessage) {
let handler = self.0.clone();
tokio::spawn(async move {
handler.did_receive_ws_data(Bytes::from(msg.data)).await;
});
}
}
2022-03-05 22:30:42 +08:00
struct BlockManagerViewDataImpl(Arc<BlockManager>);
#[async_trait]
impl ViewDataProcessor for BlockManagerViewDataImpl {
async fn create_container(&self, view_id: &str, repeated_revision: RepeatedRevision) -> FlowyResult<()> {
let _ = self.0.create_block(view_id, repeated_revision).await?;
Ok(())
}
async fn delete_container(&self, view_id: &str) -> FlowyResult<()> {
let _ = self.0.delete_block(view_id)?;
Ok(())
}
async fn close_container(&self, view_id: &str) -> FlowyResult<()> {
let _ = self.0.close_block(view_id)?;
Ok(())
}
async fn delta_str(&self, view_id: &str) -> FlowyResult<String> {
let editor = self.0.open_block(view_id).await?;
let delta_str = editor.delta_str().await?;
Ok(delta_str)
}
fn data_type(&self) -> ViewDataType {
ViewDataType::RichText
}
}
struct GridManagerViewDataImpl(Arc<GridManager>);
#[async_trait]
impl ViewDataProcessor for GridManagerViewDataImpl {
async fn create_container(&self, view_id: &str, repeated_revision: RepeatedRevision) -> FlowyResult<()> {
let _ = self.0.create_grid(view_id, repeated_revision).await?;
Ok(())
}
async fn delete_container(&self, view_id: &str) -> FlowyResult<()> {
let _ = self.0.delete_grid(view_id)?;
Ok(())
}
async fn close_container(&self, view_id: &str) -> FlowyResult<()> {
let _ = self.0.close_grid(view_id)?;
Ok(())
}
async fn delta_str(&self, view_id: &str) -> FlowyResult<String> {
let editor = self.0.open_grid(view_id).await?;
let delta_str = editor.delta_str().await;
Ok(delta_str)
}
fn data_type(&self) -> ViewDataType {
ViewDataType::Grid
}
}