555 lines
20 KiB
Rust
Raw Normal View History

2022-10-22 21:57:44 +08:00
pub use crate::entities::view::ViewDataFormatPB;
use crate::entities::{AppPB, DeletedViewPB, ViewInfoPB, ViewLayoutTypePB};
2022-03-06 09:03:02 +08:00
use crate::manager::{ViewDataProcessor, ViewDataProcessorMap};
use crate::{
dart_notification::{send_dart_notification, FolderNotification},
entities::{
2022-07-19 14:11:29 +08:00
trash::{RepeatedTrashIdPB, TrashType},
view::{CreateViewParams, RepeatedViewPB, UpdateViewParams, ViewIdPB, ViewPB},
},
2021-12-31 10:32:25 +08:00
errors::{FlowyError, FlowyResult},
2022-01-30 10:33:21 +08:00
event_map::{FolderCouldServiceV1, WorkspaceUser},
2021-12-06 15:49:21 +08:00
services::{
2022-01-17 11:55:36 +08:00
persistence::{FolderPersistence, FolderPersistenceTransaction, ViewChangeset},
2022-01-24 17:35:58 +08:00
TrashController, TrashEvent,
2021-12-06 15:49:21 +08:00
},
};
2022-03-06 09:03:02 +08:00
use bytes::Bytes;
2021-12-12 21:18:23 +08:00
use flowy_database::kv::KV;
use flowy_http_model::document::DocumentIdPB;
use folder_rev_model::{gen_view_id, ViewRevision};
2022-03-06 09:03:02 +08:00
use futures::{FutureExt, StreamExt};
use std::{collections::HashSet, sync::Arc};
2021-10-15 13:42:52 +08:00
const LATEST_VIEW_ID: &str = "latest_view_id";
2021-09-01 22:50:22 +08:00
pub(crate) struct ViewController {
2021-09-02 19:57:19 +08:00
user: Arc<dyn WorkspaceUser>,
2022-01-17 11:55:36 +08:00
cloud_service: Arc<dyn FolderCouldServiceV1>,
persistence: Arc<FolderPersistence>,
2021-12-29 21:49:31 +08:00
trash_controller: Arc<TrashController>,
2022-03-06 09:03:02 +08:00
data_processors: ViewDataProcessorMap,
2021-07-19 22:44:37 +08:00
}
impl ViewController {
2021-09-13 23:09:57 +08:00
pub(crate) fn new(
user: Arc<dyn WorkspaceUser>,
2022-01-17 11:55:36 +08:00
persistence: Arc<FolderPersistence>,
cloud_service: Arc<dyn FolderCouldServiceV1>,
2022-03-05 22:30:42 +08:00
trash_controller: Arc<TrashController>,
2022-03-06 09:03:02 +08:00
data_processors: ViewDataProcessorMap,
2021-09-13 23:09:57 +08:00
) -> Self {
Self {
user,
2022-01-10 23:45:59 +08:00
cloud_service,
2022-01-14 09:09:25 +08:00
persistence,
2022-03-05 22:30:42 +08:00
trash_controller,
data_processors,
}
2021-07-20 14:03:21 +08:00
}
2021-07-19 22:44:37 +08:00
2022-01-18 22:56:57 +08:00
pub(crate) fn initialize(&self) -> Result<(), FlowyError> {
2021-10-13 23:11:45 +08:00
self.listen_trash_can_event();
2021-10-05 14:37:45 +08:00
Ok(())
}
2022-01-23 22:33:47 +08:00
#[tracing::instrument(level = "trace", skip(self, params), fields(name = %params.name), err)]
pub(crate) async fn create_view_from_params(
&self,
mut params: CreateViewParams,
) -> Result<ViewRevision, FlowyError> {
2022-10-22 21:57:44 +08:00
let processor = self.get_data_processor(params.data_format.clone())?;
2022-03-15 19:00:28 +08:00
let user_id = self.user.user_id()?;
2022-08-18 17:40:23 +08:00
if params.view_content_data.is_empty() {
2022-09-24 20:34:31 +08:00
tracing::trace!("Create view with build-in data");
2022-08-10 17:59:28 +08:00
let view_data = processor
2022-10-22 21:57:44 +08:00
.create_default_view(
&user_id,
&params.view_id,
params.layout.clone(),
params.data_format.clone(),
)
2022-08-10 17:59:28 +08:00
.await?;
2022-08-18 17:40:23 +08:00
params.view_content_data = view_data.to_vec();
2022-01-15 23:58:36 +08:00
} else {
2022-09-24 20:34:31 +08:00
tracing::trace!("Create view with view data");
2022-03-15 19:00:28 +08:00
let delta_data = processor
2022-09-23 11:23:35 +08:00
.create_view_from_delta_data(
&user_id,
&params.view_id,
params.view_content_data.clone(),
params.layout.clone(),
)
2022-03-15 19:00:28 +08:00
.await?;
2022-03-12 09:30:13 +08:00
let _ = self
2022-09-23 11:23:35 +08:00
.create_view(
&params.view_id,
2022-10-22 21:57:44 +08:00
params.data_format.clone(),
2022-09-23 11:23:35 +08:00
params.layout.clone(),
delta_data,
)
2022-03-12 09:30:13 +08:00
.await?;
2022-01-15 23:58:36 +08:00
};
let view_rev = self.create_view_on_server(params).await?;
let _ = self.create_view_on_local(view_rev.clone()).await?;
Ok(view_rev)
2021-11-08 19:19:02 +08:00
}
2022-10-22 21:57:44 +08:00
#[tracing::instrument(level = "debug", skip(self, view_id, view_data), err)]
2022-03-06 09:03:02 +08:00
pub(crate) async fn create_view(
&self,
view_id: &str,
2022-10-22 21:57:44 +08:00
data_type: ViewDataFormatPB,
2022-09-23 11:23:35 +08:00
layout_type: ViewLayoutTypePB,
2022-10-22 21:57:44 +08:00
view_data: Bytes,
2022-03-06 09:03:02 +08:00
) -> Result<(), FlowyError> {
2022-10-22 21:57:44 +08:00
if view_data.is_empty() {
return Err(FlowyError::internal().context("The content of the view should not be empty"));
}
2022-03-05 10:59:44 +08:00
let user_id = self.user.user_id()?;
let processor = self.get_data_processor(data_type)?;
2022-10-22 21:57:44 +08:00
let _ = processor.create_view(&user_id, view_id, layout_type, view_data).await?;
Ok(())
}
pub(crate) async fn create_view_on_local(&self, view_rev: ViewRevision) -> Result<(), FlowyError> {
2022-01-14 09:09:25 +08:00
let trash_controller = self.trash_controller.clone();
2022-01-20 23:51:11 +08:00
self.persistence
.begin_transaction(|transaction| {
2022-08-18 17:40:23 +08:00
let belong_to_id = view_rev.app_id.clone();
let _ = transaction.create_view(view_rev)?;
2022-01-20 23:51:11 +08:00
let _ = notify_views_changed(&belong_to_id, trash_controller, &transaction)?;
Ok(())
})
.await
}
#[tracing::instrument(level = "debug", skip(self, view_id), err)]
pub(crate) async fn read_view(&self, view_id: &str) -> Result<ViewRevision, FlowyError> {
let view_rev = self
2022-01-20 23:51:11 +08:00
.persistence
.begin_transaction(|transaction| {
let view = transaction.read_view(view_id)?;
2022-01-20 23:51:11 +08:00
let trash_ids = self.trash_controller.read_trash_ids(&transaction)?;
if trash_ids.contains(&view.id) {
return Err(FlowyError::record_not_found());
}
Ok(view)
})
.await?;
Ok(view_rev)
2021-07-23 22:42:44 +08:00
}
2022-06-14 08:37:44 +08:00
#[tracing::instrument(level = "debug", skip(self, view_id), fields(view_id = %view_id.value), err)]
pub(crate) async fn read_view_pb(&self, view_id: ViewIdPB) -> Result<ViewInfoPB, FlowyError> {
2022-06-14 08:37:44 +08:00
let view_info = self
.persistence
.begin_transaction(|transaction| {
let view_rev = transaction.read_view(&view_id.value)?;
2022-07-19 14:11:29 +08:00
let items: Vec<ViewPB> = view_rev
2022-06-14 08:37:44 +08:00
.belongings
.into_iter()
.map(|view_rev| view_rev.into())
.collect();
2022-07-19 14:11:29 +08:00
let view_info = ViewInfoPB {
2022-06-14 08:37:44 +08:00
id: view_rev.id,
2022-08-18 17:40:23 +08:00
belong_to_id: view_rev.app_id,
2022-06-14 08:37:44 +08:00
name: view_rev.name,
desc: view_rev.desc,
2022-10-22 21:57:44 +08:00
data_type: view_rev.data_format.into(),
2022-07-19 14:11:29 +08:00
belongings: RepeatedViewPB { items },
2022-06-15 17:24:46 +08:00
ext_data: view_rev.ext_data,
2022-06-14 08:37:44 +08:00
};
Ok(view_info)
})
.await?;
Ok(view_info)
}
pub(crate) async fn read_local_views(&self, ids: Vec<String>) -> Result<Vec<ViewRevision>, FlowyError> {
2022-01-20 23:51:11 +08:00
self.persistence
.begin_transaction(|transaction| {
let mut views = vec![];
for view_id in ids {
views.push(transaction.read_view(&view_id)?);
}
Ok(views)
})
.await
}
2022-05-26 17:28:44 +08:00
#[tracing::instrument(level = "trace", skip(self), err)]
2022-03-06 21:22:42 +08:00
pub(crate) fn set_latest_view(&self, view_id: &str) -> Result<(), FlowyError> {
2022-02-25 22:27:44 +08:00
KV::set_str(LATEST_VIEW_ID, view_id.to_owned());
2022-03-06 21:22:42 +08:00
Ok(())
}
2022-01-15 23:58:36 +08:00
#[tracing::instrument(level = "debug", skip(self), err)]
2022-03-06 09:03:02 +08:00
pub(crate) async fn close_view(&self, view_id: &str) -> Result<(), FlowyError> {
let processor = self.get_data_processor_from_view_id(view_id).await?;
2022-10-22 21:57:44 +08:00
let _ = processor.close_view(view_id).await?;
Ok(())
}
2022-02-24 21:49:18 +08:00
#[tracing::instrument(level = "debug", skip(self,params), fields(doc_id = %params.value), err)]
2022-10-13 23:29:37 +08:00
pub(crate) async fn move_view_to_trash(&self, params: DocumentIdPB) -> Result<(), FlowyError> {
let view_id = params.value;
if let Some(latest_view_id) = KV::get_str(LATEST_VIEW_ID) {
if latest_view_id == view_id {
2021-11-11 19:56:30 +08:00
let _ = KV::remove(LATEST_VIEW_ID);
}
}
let deleted_view = self
.persistence
.begin_transaction(|transaction| {
let view = transaction.read_view(&view_id)?;
let views = read_belonging_views_on_local(&view.app_id, self.trash_controller.clone(), &transaction)?;
let index = views
.iter()
.position(|view| view.id == view_id)
2022-09-27 14:20:18 +08:00
.map(|index| index as i32);
Ok(DeletedViewPB {
view_id: view_id.clone(),
index,
})
})
.await?;
send_dart_notification(&view_id, FolderNotification::ViewMoveToTrash)
.payload(deleted_view)
.send();
let processor = self.get_data_processor_from_view_id(&view_id).await?;
2022-10-22 21:57:44 +08:00
let _ = processor.close_view(&view_id).await?;
Ok(())
}
2022-04-26 21:20:02 +08:00
#[tracing::instrument(level = "debug", skip(self), err)]
pub(crate) async fn move_view(&self, view_id: &str, from: usize, to: usize) -> Result<(), FlowyError> {
let _ = self
.persistence
.begin_transaction(|transaction| {
let _ = transaction.move_view(view_id, from, to)?;
let view = transaction.read_view(view_id)?;
2022-08-18 17:40:23 +08:00
let _ = notify_views_changed(&view.app_id, self.trash_controller.clone(), &transaction)?;
2022-04-26 21:20:02 +08:00
Ok(())
})
.await?;
Ok(())
}
2022-01-15 23:58:36 +08:00
#[tracing::instrument(level = "debug", skip(self), err)]
2022-10-22 21:57:44 +08:00
pub(crate) async fn duplicate_view(&self, view: ViewPB) -> Result<(), FlowyError> {
let view_rev = self
2022-01-14 09:09:25 +08:00
.persistence
2022-10-22 21:57:44 +08:00
.begin_transaction(|transaction| transaction.read_view(&view.id))
2022-01-20 23:51:11 +08:00
.await?;
2022-01-14 09:09:25 +08:00
2022-10-22 21:57:44 +08:00
let processor = self.get_data_processor(view_rev.data_format.clone())?;
let view_data = processor.get_view_data(&view).await?;
let duplicate_params = CreateViewParams {
2022-08-18 17:40:23 +08:00
belong_to_id: view_rev.app_id.clone(),
name: format!("{} (copy)", &view_rev.name),
desc: view_rev.desc,
thumbnail: view_rev.thumbnail,
2022-10-22 21:57:44 +08:00
data_format: view_rev.data_format.into(),
layout: view_rev.layout.into(),
2022-09-24 20:34:31 +08:00
view_content_data: view_data.to_vec(),
2022-04-11 15:27:03 +08:00
view_id: gen_view_id(),
};
2021-11-08 19:19:02 +08:00
let _ = self.create_view_from_params(duplicate_params).await?;
Ok(())
}
2021-09-02 19:57:19 +08:00
// belong_to_id will be the app_id or view_id.
2022-05-26 17:28:44 +08:00
#[tracing::instrument(level = "trace", skip(self), err)]
pub(crate) async fn read_views_belong_to(&self, belong_to_id: &str) -> Result<Vec<ViewRevision>, FlowyError> {
2022-01-20 23:51:11 +08:00
self.persistence
.begin_transaction(|transaction| {
read_belonging_views_on_local(belong_to_id, self.trash_controller.clone(), &transaction)
})
.await
}
2021-10-13 23:11:45 +08:00
#[tracing::instrument(level = "debug", skip(self, params), err)]
pub(crate) async fn update_view(&self, params: UpdateViewParams) -> Result<ViewRevision, FlowyError> {
2022-01-13 11:16:26 +08:00
let changeset = ViewChangeset::new(params.clone());
2022-06-15 11:43:24 +08:00
let view_id = changeset.id.clone();
let view_rev = self
.persistence
.begin_transaction(|transaction| {
let _ = transaction.update_view(changeset)?;
let view_rev = transaction.read_view(&view_id)?;
2022-07-19 14:11:29 +08:00
let view: ViewPB = view_rev.clone().into();
2022-06-15 11:43:24 +08:00
send_dart_notification(&view_id, FolderNotification::ViewUpdated)
.payload(view)
.send();
2022-08-18 17:40:23 +08:00
let _ = notify_views_changed(&view_rev.app_id, self.trash_controller.clone(), &transaction)?;
2022-06-15 11:43:24 +08:00
Ok(view_rev)
})
.await?;
let _ = self.update_view_on_server(params);
Ok(view_rev)
}
pub(crate) async fn latest_visit_view(&self) -> FlowyResult<Option<ViewRevision>> {
match KV::get_str(LATEST_VIEW_ID) {
None => Ok(None),
Some(view_id) => {
let view_rev = self
2022-01-14 09:09:25 +08:00
.persistence
2022-01-20 23:51:11 +08:00
.begin_transaction(|transaction| transaction.read_view(&view_id))
.await?;
Ok(Some(view_rev))
2022-01-24 17:35:58 +08:00
}
}
}
2021-09-02 19:57:19 +08:00
}
impl ViewController {
2022-06-06 20:06:08 +08:00
#[tracing::instrument(level = "debug", skip(self, params), err)]
async fn create_view_on_server(&self, params: CreateViewParams) -> Result<ViewRevision, FlowyError> {
2021-09-02 19:57:19 +08:00
let token = self.user.token()?;
let view_rev = self.cloud_service.create_view(&token, params).await?;
Ok(view_rev)
2021-09-02 19:57:19 +08:00
}
2022-04-12 11:13:35 +08:00
#[tracing::instrument(level = "debug", skip(self), err)]
2021-12-14 18:04:51 +08:00
fn update_view_on_server(&self, params: UpdateViewParams) -> Result<(), FlowyError> {
2021-09-02 19:57:19 +08:00
let token = self.user.token()?;
2022-01-10 23:45:59 +08:00
let server = self.cloud_service.clone();
2021-11-09 15:32:57 +08:00
tokio::spawn(async move {
2021-09-02 19:57:19 +08:00
match server.update_view(&token, params).await {
2022-01-24 17:35:58 +08:00
Ok(_) => {}
2021-09-02 19:57:19 +08:00
Err(e) => {
// TODO: retry?
log::error!("Update view failed: {:?}", e);
2022-01-24 17:35:58 +08:00
}
2021-09-02 19:57:19 +08:00
}
});
Ok(())
}
2022-04-12 11:13:35 +08:00
#[tracing::instrument(level = "debug", skip(self), err)]
2022-07-19 14:11:29 +08:00
fn read_view_on_server(&self, params: ViewIdPB) -> Result<(), FlowyError> {
2021-09-02 19:57:19 +08:00
let token = self.user.token()?;
2022-01-10 23:45:59 +08:00
let server = self.cloud_service.clone();
2022-01-14 09:09:25 +08:00
let persistence = self.persistence.clone();
2022-01-01 14:23:58 +08:00
// TODO: Retry with RetryAction?
2021-11-09 15:32:57 +08:00
tokio::spawn(async move {
2021-09-02 19:57:19 +08:00
match server.read_view(&token, params).await {
Ok(Some(view_rev)) => {
2022-01-20 23:51:11 +08:00
match persistence
.begin_transaction(|transaction| transaction.create_view(view_rev.clone()))
2022-01-20 23:51:11 +08:00
.await
{
2022-01-14 09:09:25 +08:00
Ok(_) => {
2022-07-19 14:11:29 +08:00
let view: ViewPB = view_rev.into();
send_dart_notification(&view.id, FolderNotification::ViewUpdated)
.payload(view)
2022-01-14 09:09:25 +08:00
.send();
2022-01-24 17:35:58 +08:00
}
2022-01-14 09:09:25 +08:00
Err(e) => log::error!("Save view failed: {:?}", e),
}
2022-01-24 17:35:58 +08:00
}
Ok(None) => {}
Err(e) => log::error!("Read view failed: {:?}", e),
2021-09-02 19:57:19 +08:00
}
});
2021-07-23 22:42:44 +08:00
Ok(())
}
2021-10-13 23:11:45 +08:00
fn listen_trash_can_event(&self) {
2021-12-29 21:49:31 +08:00
let mut rx = self.trash_controller.subscribe();
2022-01-14 09:09:25 +08:00
let persistence = self.persistence.clone();
2022-03-06 09:03:02 +08:00
let data_processors = self.data_processors.clone();
2022-01-14 09:09:25 +08:00
let trash_controller = self.trash_controller.clone();
2021-10-13 23:11:45 +08:00
let _ = tokio::spawn(async move {
loop {
let mut stream = Box::pin(rx.recv().into_stream().filter_map(|result| async move {
match result {
Ok(event) => event.select(TrashType::TrashView),
Err(_e) => None,
2021-10-13 23:11:45 +08:00
}
}));
2021-11-27 19:19:41 +08:00
if let Some(event) = stream.next().await {
2022-01-22 18:48:43 +08:00
handle_trash_event(
persistence.clone(),
2022-03-06 09:03:02 +08:00
data_processors.clone(),
2022-01-22 18:48:43 +08:00
trash_controller.clone(),
event,
)
.await
2021-10-13 23:11:45 +08:00
}
}
});
}
2022-03-06 09:03:02 +08:00
async fn get_data_processor_from_view_id(
&self,
view_id: &str,
) -> FlowyResult<Arc<dyn ViewDataProcessor + Send + Sync>> {
let view = self
.persistence
.begin_transaction(|transaction| transaction.read_view(view_id))
.await?;
2022-10-22 21:57:44 +08:00
self.get_data_processor(view.data_format)
2022-03-06 09:03:02 +08:00
}
#[inline]
2022-10-22 21:57:44 +08:00
fn get_data_processor<T: Into<ViewDataFormatPB>>(
&self,
data_type: T,
) -> FlowyResult<Arc<dyn ViewDataProcessor + Send + Sync>> {
let data_type = data_type.into();
match self.data_processors.get(&data_type) {
2022-03-06 09:03:02 +08:00
None => Err(FlowyError::internal().context(format!(
"Get data processor failed. Unknown view data type: {:?}",
data_type
))),
Some(processor) => Ok(processor.clone()),
}
}
2021-10-13 23:11:45 +08:00
}
2022-03-06 09:03:02 +08:00
#[tracing::instrument(level = "trace", skip(persistence, data_processors, trash_can))]
2021-10-16 21:22:59 +08:00
async fn handle_trash_event(
2022-01-17 11:55:36 +08:00
persistence: Arc<FolderPersistence>,
2022-03-06 09:03:02 +08:00
data_processors: ViewDataProcessorMap,
2021-12-06 15:49:21 +08:00
trash_can: Arc<TrashController>,
2021-10-16 21:22:59 +08:00
event: TrashEvent,
) {
match event {
TrashEvent::NewTrash(identifiers, ret) => {
2022-01-20 23:51:11 +08:00
let result = persistence
.begin_transaction(|transaction| {
let view_revs = read_local_views_with_transaction(identifiers, &transaction)?;
for view_rev in view_revs {
2022-08-18 17:40:23 +08:00
let _ = notify_views_changed(&view_rev.app_id, trash_can.clone(), &transaction)?;
notify_dart(view_rev.into(), FolderNotification::ViewDeleted);
2022-01-20 23:51:11 +08:00
}
Ok(())
})
.await;
2022-01-14 09:09:25 +08:00
let _ = ret.send(result).await;
2022-01-24 17:35:58 +08:00
}
TrashEvent::Putback(identifiers, ret) => {
2022-01-20 23:51:11 +08:00
let result = persistence
.begin_transaction(|transaction| {
let view_revs = read_local_views_with_transaction(identifiers, &transaction)?;
for view_rev in view_revs {
2022-08-18 17:40:23 +08:00
let _ = notify_views_changed(&view_rev.app_id, trash_can.clone(), &transaction)?;
notify_dart(view_rev.into(), FolderNotification::ViewRestored);
2022-01-20 23:51:11 +08:00
}
Ok(())
})
.await;
2022-01-14 09:09:25 +08:00
let _ = ret.send(result).await;
2022-01-24 17:35:58 +08:00
}
TrashEvent::Delete(identifiers, ret) => {
2022-03-06 09:03:02 +08:00
let result = || async {
let views = persistence
.begin_transaction(|transaction| {
let mut notify_ids = HashSet::new();
let mut views = vec![];
for identifier in identifiers.items {
2022-10-26 22:36:34 +08:00
if let Ok(view_rev) = transaction.delete_view(&identifier.id) {
notify_ids.insert(view_rev.app_id.clone());
views.push(view_rev);
}
2022-03-06 09:03:02 +08:00
}
for notify_id in notify_ids {
let _ = notify_views_changed(&notify_id, trash_can.clone(), &transaction)?;
}
Ok(views)
})
.await?;
2022-03-06 09:03:02 +08:00
for view in views {
2022-10-22 21:57:44 +08:00
let data_type = view.data_format.clone().into();
match get_data_processor(data_processors.clone(), &data_type) {
2022-03-06 09:03:02 +08:00
Ok(processor) => {
2022-10-22 21:57:44 +08:00
let _ = processor.close_view(&view.id).await?;
2022-03-06 09:03:02 +08:00
}
2022-10-26 22:36:34 +08:00
Err(e) => tracing::error!("{}", e),
2022-01-20 23:51:11 +08:00
}
2022-03-06 09:03:02 +08:00
}
Ok(())
};
let _ = ret.send(result().await).await;
2022-01-24 17:35:58 +08:00
}
2021-10-13 23:11:45 +08:00
}
2021-07-19 22:44:37 +08:00
}
2022-03-06 09:03:02 +08:00
fn get_data_processor(
data_processors: ViewDataProcessorMap,
2022-10-22 21:57:44 +08:00
data_type: &ViewDataFormatPB,
2022-03-06 09:03:02 +08:00
) -> FlowyResult<Arc<dyn ViewDataProcessor + Send + Sync>> {
match data_processors.get(data_type) {
None => Err(FlowyError::internal().context(format!(
"Get data processor failed. Unknown view data type: {:?}",
data_type
))),
Some(processor) => Ok(processor.clone()),
}
}
2022-01-14 09:09:25 +08:00
fn read_local_views_with_transaction<'a>(
2022-07-19 14:11:29 +08:00
identifiers: RepeatedTrashIdPB,
2022-01-17 11:55:36 +08:00
transaction: &'a (dyn FolderPersistenceTransaction + 'a),
) -> Result<Vec<ViewRevision>, FlowyError> {
let mut view_revs = vec![];
2022-01-14 09:09:25 +08:00
for identifier in identifiers.items {
view_revs.push(transaction.read_view(&identifier.id)?);
2022-01-14 09:09:25 +08:00
}
Ok(view_revs)
}
2022-07-19 14:11:29 +08:00
fn notify_dart(view: ViewPB, notification: FolderNotification) {
send_dart_notification(&view.id, notification).payload(view).send();
}
2022-04-12 11:13:35 +08:00
#[tracing::instrument(
level = "debug",
skip(belong_to_id, trash_controller, transaction),
fields(view_count),
err
)]
2022-01-14 09:09:25 +08:00
fn notify_views_changed<'a>(
2021-12-06 15:49:21 +08:00
belong_to_id: &str,
2021-12-29 21:49:31 +08:00
trash_controller: Arc<TrashController>,
2022-01-17 11:55:36 +08:00
transaction: &'a (dyn FolderPersistenceTransaction + 'a),
2021-12-14 18:04:51 +08:00
) -> FlowyResult<()> {
let mut app_rev = transaction.read_app(belong_to_id)?;
let trash_ids = trash_controller.read_trash_ids(transaction)?;
app_rev.belongings.retain(|view| !trash_ids.contains(&view.id));
let app: AppPB = app_rev.into();
send_dart_notification(belong_to_id, FolderNotification::AppUpdated)
.payload(app)
.send();
Ok(())
}
2021-10-16 21:22:59 +08:00
2022-01-14 09:09:25 +08:00
fn read_belonging_views_on_local<'a>(
2021-10-16 21:22:59 +08:00
belong_to_id: &str,
2021-12-29 00:34:00 +08:00
trash_controller: Arc<TrashController>,
2022-01-17 11:55:36 +08:00
transaction: &'a (dyn FolderPersistenceTransaction + 'a),
) -> FlowyResult<Vec<ViewRevision>> {
let mut view_revs = transaction.read_views(belong_to_id)?;
2022-01-14 09:09:25 +08:00
let trash_ids = trash_controller.read_trash_ids(transaction)?;
view_revs.retain(|view_table| !trash_ids.contains(&view_table.id));
2021-10-30 17:19:50 +08:00
Ok(view_revs)
2021-10-16 21:22:59 +08:00
}