2021-02-20 00:10:05 +01:00
|
|
|
use std::error::Error;
|
2021-03-05 23:32:42 +01:00
|
|
|
use std::collections::{HashMap, HashSet};
|
2021-03-18 23:59:06 +01:00
|
|
|
use std::sync::{Arc, Mutex};
|
2021-02-18 12:02:04 +01:00
|
|
|
|
2021-02-25 00:47:39 +01:00
|
|
|
use async_trait::async_trait;
|
2021-02-18 12:02:04 +01:00
|
|
|
|
2021-03-01 23:39:16 +01:00
|
|
|
use crate::item::Item;
|
|
|
|
use crate::item::ItemId;
|
2021-03-22 22:06:43 +01:00
|
|
|
use crate::item::VersionTag;
|
2021-03-05 23:32:42 +01:00
|
|
|
use crate::calendar::CalendarId;
|
2021-02-18 12:02:04 +01:00
|
|
|
|
2021-02-25 00:47:39 +01:00
|
|
|
#[async_trait]
|
2021-03-01 23:39:16 +01:00
|
|
|
pub trait CalDavSource<T: PartialCalendar> {
|
2021-02-25 00:47:39 +01:00
|
|
|
/// Returns the current calendars that this source contains
|
|
|
|
/// This function may trigger an update (that can be a long process, or that can even fail, e.g. in case of a remote server)
|
2021-03-18 23:59:06 +01:00
|
|
|
async fn get_calendars(&self) -> Result<HashMap<CalendarId, Arc<Mutex<T>>>, Box<dyn Error>>;
|
2021-03-05 23:32:42 +01:00
|
|
|
/// Returns the calendar matching the ID
|
2021-03-21 19:27:55 +01:00
|
|
|
async fn get_calendar(&self, id: &CalendarId) -> Option<Arc<Mutex<T>>>;
|
2021-02-18 12:02:04 +01:00
|
|
|
}
|
2021-02-28 18:00:37 +01:00
|
|
|
|
2021-03-01 23:39:16 +01:00
|
|
|
/// A calendar we have a partial knowledge of.
|
|
|
|
///
|
|
|
|
/// Usually, this is a calendar from a remote source, that is synced to a CompleteCalendar
|
2021-03-21 19:05:22 +01:00
|
|
|
#[async_trait]
|
2021-03-01 23:39:16 +01:00
|
|
|
pub trait PartialCalendar {
|
|
|
|
/// Returns the calendar name
|
|
|
|
fn name(&self) -> &str;
|
|
|
|
|
2021-03-05 23:32:42 +01:00
|
|
|
/// Returns the calendar unique ID
|
|
|
|
fn id(&self) -> &CalendarId;
|
2021-03-01 23:39:16 +01:00
|
|
|
|
|
|
|
/// Returns the supported kinds of components for this calendar
|
|
|
|
fn supported_components(&self) -> crate::calendar::SupportedComponents;
|
|
|
|
|
2021-03-22 22:06:43 +01:00
|
|
|
/// Get the IDs and the version tags of every item in this calendar
|
|
|
|
async fn get_item_version_tags(&self) -> Result<HashMap<ItemId, VersionTag>, Box<dyn Error>>;
|
2021-03-02 00:21:58 +01:00
|
|
|
|
2021-03-01 23:39:16 +01:00
|
|
|
/// Returns a particular item
|
2021-03-21 19:19:49 +01:00
|
|
|
async fn get_item_by_id_mut<'a>(&'a mut self, id: &ItemId) -> Option<&'a mut Item>;
|
2021-03-01 23:39:16 +01:00
|
|
|
|
2021-03-22 23:42:41 +01:00
|
|
|
/// Returns a particular item
|
|
|
|
async fn get_item_by_id<'a>(&'a self, id: &ItemId) -> Option<&'a Item>;
|
|
|
|
|
2021-03-01 23:39:16 +01:00
|
|
|
/// Add an item into this calendar
|
2021-03-21 19:19:49 +01:00
|
|
|
async fn add_item(&mut self, item: Item);
|
2021-03-01 23:39:16 +01:00
|
|
|
|
|
|
|
/// Remove an item from this calendar
|
2021-03-21 19:19:49 +01:00
|
|
|
async fn delete_item(&mut self, item_id: &ItemId) -> Result<(), Box<dyn Error>>;
|
2021-03-01 23:39:16 +01:00
|
|
|
|
2021-03-02 00:21:58 +01:00
|
|
|
|
|
|
|
/// Returns whether this calDAV calendar supports to-do items
|
|
|
|
fn supports_todo(&self) -> bool {
|
|
|
|
self.supported_components().contains(crate::calendar::SupportedComponents::TODO)
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns whether this calDAV calendar supports calendar items
|
|
|
|
fn supports_events(&self) -> bool {
|
|
|
|
self.supported_components().contains(crate::calendar::SupportedComponents::EVENT)
|
|
|
|
}
|
|
|
|
|
2021-03-22 22:06:43 +01:00
|
|
|
/// Get the IDs of all current items in this calendar
|
|
|
|
async fn get_item_ids(&self) -> Result<HashSet<ItemId>, Box<dyn Error>> {
|
|
|
|
let items = self.get_item_version_tags().await?;
|
|
|
|
Ok(items.iter()
|
|
|
|
.map(|(id, _tag)| id.clone())
|
|
|
|
.collect())
|
|
|
|
}
|
|
|
|
|
2021-03-02 00:21:58 +01:00
|
|
|
/// Finds the IDs of the items that are missing compared to a reference set
|
2021-03-21 23:53:42 +01:00
|
|
|
async fn find_deletions_from(&self, reference_set: HashSet<ItemId>) -> Result<HashSet<ItemId>, Box<dyn Error>> {
|
|
|
|
let current_items = self.get_item_ids().await?;
|
|
|
|
Ok(reference_set.difference(¤t_items).map(|id| id.clone()).collect())
|
2021-03-02 00:21:58 +01:00
|
|
|
}
|
2021-03-01 23:39:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/// A calendar we always know everything about.
|
|
|
|
///
|
|
|
|
/// Usually, this is a calendar fully stored on a local disk
|
2021-03-21 19:05:22 +01:00
|
|
|
#[async_trait]
|
2021-03-01 23:39:16 +01:00
|
|
|
pub trait CompleteCalendar : PartialCalendar {
|
|
|
|
/// Returns the list of items that this calendar contains
|
2021-03-21 19:58:37 +01:00
|
|
|
async fn get_items(&self) -> Result<HashMap<ItemId, &Item>, Box<dyn Error>>;
|
2021-03-01 23:39:16 +01:00
|
|
|
}
|
|
|
|
|