kitchen-freezer/src/lib.rs

49 lines
2.1 KiB
Rust
Raw Normal View History

2021-02-22 00:13:29 +01:00
//! This crate provides a way to manage CalDAV data.
//!
2021-04-28 23:21:13 +02:00
//! Its initial implementation only supported TODO events, so that it could fetch and update a CalDAV-hosted todo-list...just like [sticky notes on a kitchen fridge](https://www.google.com/search?q=kitchen+fridge+todo+list&tbm=isch) would. \
//! Supporting other items (and especially regular CalDAV calendar events) should be fairly trivial, as it should boil down to adding little logic in iCal files parsing, but any help is appreciated :-)
//!
//! ## Possible uses
//!
2021-02-22 00:13:29 +01:00
//! It provides a CalDAV client in the [`client`] module, that can be used as a stand-alone module.
//!
2021-04-28 23:21:13 +02:00
//! Because the connection to the server may be slow, this crate also provides a local cache for CalDAV data in the [`cache`] module.
//! This way, user-frendly apps are able to quicky display cached data on startup.
2021-02-22 00:13:29 +01:00
//!
2021-04-28 23:21:13 +02:00
//! These two "data sources" (actual client and local cache) can be used together in a [`CalDavProvider`](CalDavProvider). \
//! A `CalDavProvider` abstracts these two sources by merging them together into one virtual source. \
2021-02-22 00:13:29 +01:00
//! It also handles synchronisation between the local cache and the server.
2021-04-03 16:27:04 +02:00
//!
//! Note that many methods are defined in common traits (see [`crate::traits`]).
//!
2021-04-28 23:21:13 +02:00
//! ## Examples
//!
2021-11-03 21:55:48 +01:00
//! See example usage in the `examples/` folder, that you can run using `cargo run --example <example-name>`. \
//! You can also have a look at `tasklist`, a GUI app that uses `kitchen-fridge` under the hood.
2021-02-22 00:13:29 +01:00
2021-02-25 00:47:39 +01:00
pub mod traits;
2021-02-24 23:49:20 +01:00
pub mod calendar;
2021-04-28 23:43:03 +02:00
pub mod item;
pub use item::Item;
pub mod task;
2021-02-22 00:13:29 +01:00
pub use task::Task;
2021-04-28 23:43:03 +02:00
pub mod event;
pub use event::Event;
2021-02-27 11:58:40 +01:00
pub mod provider;
2021-04-13 23:32:07 +02:00
pub mod mock_behaviour;
2021-02-22 00:13:29 +01:00
pub mod client;
2021-04-03 18:57:40 +02:00
pub use client::Client;
2021-02-22 00:13:29 +01:00
pub mod cache;
2021-07-05 11:05:22 +02:00
pub use cache::Cache;
2021-03-29 09:31:22 +02:00
pub mod ical;
2021-02-22 00:13:29 +01:00
pub mod config;
2021-02-21 00:29:22 +01:00
pub mod utils;
pub mod resource;
2021-04-28 23:43:03 +02:00
/// Unless you want another kind of Provider to write integration tests, you'll probably want this kind of Provider. \
/// See alse the [`Provider` documentation](crate::provider::Provider)
pub type CalDavProvider = provider::Provider<cache::Cache, calendar::cached_calendar::CachedCalendar, Client, calendar::remote_calendar::RemoteCalendar>;