1use crate::Lb;
2use crate::model::api::GetPublicKeyRequest;
3use crate::model::errors::{LbErr, LbResult};
4use crate::model::file::{File, ShareMode};
5use crate::model::file_metadata::Owner;
6use crate::model::tree_like::TreeLike;
7use crate::service::events::Actor;
8use libsecp256k1::PublicKey;
9use uuid::Uuid;
10
11impl Lb {
12 #[instrument(level = "debug", skip(self))]
14 pub async fn share_file(&self, id: Uuid, username: &str, mode: ShareMode) -> LbResult<()> {
15 let account = self.get_account()?;
16 let username = username.to_lowercase();
17
18 let sharee = Owner(
19 self.client
20 .request(account, GetPublicKeyRequest { username: username.clone() })
21 .await
22 .map_err(LbErr::from)?
23 .key,
24 );
25
26 let mut tx = self.begin_tx().await;
27 let db = tx.db();
28
29 let mut tree = (&db.base_metadata)
30 .to_staged(&mut db.local_metadata)
31 .to_lazy();
32 db.pub_key_lookup.insert(sharee, username)?;
33
34 tree.add_share(id, sharee, mode, &self.keychain)?;
35
36 tx.end();
37
38 self.events.meta_changed(Actor::User);
39
40 Ok(())
41 }
42
43 #[instrument(level = "debug", skip(self))]
47 pub async fn get_pending_shares(&self) -> LbResult<Vec<File>> {
48 let tx = self.ro_tx().await;
49 let db = tx.db();
50
51 let mut tree = (&db.base_metadata).to_staged(&db.local_metadata).to_lazy();
52 let pending_roots = tree.pending_roots(&self.keychain)?.into_iter();
53
54 tree.decrypt_all(&self.keychain, pending_roots, &db.pub_key_lookup, false)
55 }
56
57 #[instrument(level = "debug", skip(self))]
60 pub async fn get_pending_share_files(&self) -> LbResult<Vec<File>> {
61 let tx = self.ro_tx().await;
62 let db = tx.db();
63
64 let mut tree = (&db.base_metadata).to_staged(&db.local_metadata).to_lazy();
65 let pending_files = tree.non_deleted_pending_files(&self.keychain)?.into_iter();
66
67 tree.decrypt_all(&self.keychain, pending_files, &db.pub_key_lookup, false)
68 }
69
70 #[instrument(level = "debug", skip(self))]
71 async fn delete_share(
72 &self, id: &Uuid, maybe_encrypted_for: Option<PublicKey>,
73 ) -> LbResult<()> {
74 let mut tx = self.begin_tx().await;
75 let db = tx.db();
76
77 let mut tree = (&db.base_metadata)
78 .to_staged(&mut db.local_metadata)
79 .to_lazy();
80
81 tree.delete_share(id, maybe_encrypted_for, &self.keychain)?;
82
83 tx.end();
84 self.events.meta_changed(Actor::User);
85
86 Ok(())
87 }
88
89 #[instrument(level = "debug", skip(self))]
90 pub async fn known_usernames(&self) -> LbResult<Vec<String>> {
91 let db = self.ro_tx().await;
92 let db = db.db();
93
94 Ok(db.pub_key_lookup.get().values().cloned().collect())
95 }
96
97 #[instrument(level = "debug", skip(self))]
98 pub async fn reject_share(&self, id: &Uuid) -> Result<(), LbErr> {
99 let pk = self.keychain.get_pk()?;
100 self.delete_share(id, Some(pk)).await
101 }
102}