2021-09-20 15:38:55 +08:00
|
|
|
use bytes::Bytes;
|
2022-01-15 11:20:28 +08:00
|
|
|
use flowy_collaboration::entities::ws_data::ClientRevisionWSData;
|
2021-11-19 12:18:46 +08:00
|
|
|
use flowy_database::ConnectionPool;
|
2021-09-20 15:38:55 +08:00
|
|
|
use flowy_document::{
|
2021-12-14 18:04:51 +08:00
|
|
|
errors::{internal_error, FlowyError},
|
2022-02-25 22:27:44 +08:00
|
|
|
BlockCloudService, BlockManager, BlockUser,
|
2022-01-10 23:45:59 +08:00
|
|
|
};
|
2022-02-07 10:37:01 +08:00
|
|
|
use flowy_net::ClientServerConfiguration;
|
2022-01-10 23:45:59 +08:00
|
|
|
use flowy_net::{
|
2022-02-25 22:27:44 +08:00
|
|
|
http_server::document::BlockHttpCloudService, local_server::LocalServer, ws::connection::FlowyWebSocketConnect,
|
2021-11-19 12:18:46 +08:00
|
|
|
};
|
2022-01-14 15:23:21 +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};
|
2021-11-19 12:18:46 +08:00
|
|
|
use std::{convert::TryInto, path::Path, sync::Arc};
|
2021-09-20 15:38:55 +08:00
|
|
|
|
2021-12-14 15:31:44 +08:00
|
|
|
pub struct DocumentDepsResolver();
|
2021-09-20 15:38:55 +08:00
|
|
|
impl DocumentDepsResolver {
|
2021-12-14 15:31:44 +08:00
|
|
|
pub fn resolve(
|
2022-01-13 10:53:30 +08:00
|
|
|
local_server: Option<Arc<LocalServer>>,
|
2022-01-07 17:37:11 +08:00
|
|
|
ws_conn: Arc<FlowyWebSocketConnect>,
|
2021-12-14 15:31:44 +08:00
|
|
|
user_session: Arc<UserSession>,
|
2022-01-10 23:45:59 +08:00
|
|
|
server_config: &ClientServerConfiguration,
|
2022-02-25 22:27:44 +08:00
|
|
|
) -> Arc<BlockManager> {
|
2022-02-26 11:03:42 +08:00
|
|
|
let user = Arc::new(BlockUserImpl(user_session));
|
2022-02-25 22:27:44 +08:00
|
|
|
let ws_sender = Arc::new(BlockWebSocket(ws_conn.clone()));
|
|
|
|
let cloud_service: Arc<dyn BlockCloudService> = match local_server {
|
|
|
|
None => Arc::new(BlockHttpCloudService::new(server_config.clone())),
|
2022-01-13 10:53:30 +08:00
|
|
|
Some(local_server) => local_server,
|
|
|
|
};
|
|
|
|
|
2022-02-25 22:27:44 +08:00
|
|
|
let manager = Arc::new(BlockManager::new(cloud_service, user, ws_sender));
|
2022-01-22 18:48:43 +08:00
|
|
|
let receiver = Arc::new(DocumentWSMessageReceiverImpl(manager.clone()));
|
2022-01-14 20:52:03 +08:00
|
|
|
ws_conn.add_ws_message_receiver(receiver).unwrap();
|
|
|
|
|
2022-01-22 18:48:43 +08:00
|
|
|
manager
|
2021-09-20 15:38:55 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-26 11:03:42 +08:00
|
|
|
struct BlockUserImpl(Arc<UserSession>);
|
|
|
|
impl BlockUser for BlockUserImpl {
|
2021-12-14 18:04:51 +08:00
|
|
|
fn user_dir(&self) -> Result<String, FlowyError> {
|
2022-01-10 23:45:59 +08:00
|
|
|
let dir = self.0.user_dir().map_err(|e| FlowyError::unauthorized().context(e))?;
|
2021-09-20 15:38:55 +08:00
|
|
|
|
2021-12-21 11:13:38 +08:00
|
|
|
let doc_dir = format!("{}/document", dir);
|
2021-09-20 15:38:55 +08:00
|
|
|
if !Path::new(&doc_dir).exists() {
|
|
|
|
let _ = std::fs::create_dir_all(&doc_dir)?;
|
|
|
|
}
|
|
|
|
Ok(doc_dir)
|
|
|
|
}
|
|
|
|
|
2022-01-24 17:35:58 +08:00
|
|
|
fn user_id(&self) -> Result<String, FlowyError> {
|
|
|
|
self.0.user_id()
|
|
|
|
}
|
2021-09-20 15:38:55 +08:00
|
|
|
|
2022-01-24 17:35:58 +08:00
|
|
|
fn token(&self) -> Result<String, FlowyError> {
|
|
|
|
self.0.token()
|
|
|
|
}
|
2021-11-13 11:53:50 +08:00
|
|
|
|
2022-01-24 17:35:58 +08:00
|
|
|
fn db_pool(&self) -> Result<Arc<ConnectionPool>, FlowyError> {
|
|
|
|
self.0.db_pool()
|
|
|
|
}
|
2021-09-20 15:38:55 +08:00
|
|
|
}
|
|
|
|
|
2022-02-25 22:27:44 +08:00
|
|
|
struct BlockWebSocket(Arc<FlowyWebSocketConnect>);
|
|
|
|
impl RevisionWebSocket for BlockWebSocket {
|
2022-01-24 16:27:40 +08:00
|
|
|
fn send(&self, data: ClientRevisionWSData) -> BoxResultFuture<(), FlowyError> {
|
2021-12-10 22:18:44 +08:00
|
|
|
let bytes: Bytes = data.try_into().unwrap();
|
2021-12-26 19:10:37 +08:00
|
|
|
let msg = WebSocketRawMessage {
|
2022-01-22 18:48:43 +08:00
|
|
|
channel: WSChannel::Document,
|
2021-12-10 22:18:44 +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(())
|
|
|
|
})
|
2021-09-20 15:38:55 +08:00
|
|
|
}
|
2021-10-04 14:24:35 +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 })
|
|
|
|
}
|
2021-09-20 15:38:55 +08:00
|
|
|
}
|
|
|
|
|
2022-02-25 22:27:44 +08:00
|
|
|
struct DocumentWSMessageReceiverImpl(Arc<BlockManager>);
|
2022-01-14 20:52:03 +08:00
|
|
|
impl WSMessageReceiver for DocumentWSMessageReceiverImpl {
|
2022-01-24 17:35:58 +08:00
|
|
|
fn source(&self) -> WSChannel {
|
|
|
|
WSChannel::Document
|
|
|
|
}
|
2022-01-12 12:40:41 +08:00
|
|
|
fn receive_message(&self, msg: WebSocketRawMessage) {
|
2022-01-14 20:52:03 +08:00
|
|
|
let handler = self.0.clone();
|
2022-01-12 12:40:41 +08:00
|
|
|
tokio::spawn(async move {
|
2022-02-18 23:04:55 +08:00
|
|
|
handler.receive_ws_data(Bytes::from(msg.data)).await;
|
2022-01-12 12:40:41 +08:00
|
|
|
});
|
|
|
|
}
|
2021-09-20 15:38:55 +08:00
|
|
|
}
|