Skip to content

Commit

Permalink
Split into multiple module, document all structs and general cleanup (#…
Browse files Browse the repository at this point in the history
…205)

1. Importing of types should be obvious and unique. We try not to re-export types (with one exception of the `Manager`).
2. The Store trait is split and is not an overarching trait anymore. Instead it is combined from several smaller traits, each responsible for a non-overlapping feature.
3. All public modules and types are documented (in presage).

* Split manager in files per state
* Use qualified path for log
* Rename PrekeysStore to PreKeyStoreExt
* Remove all deprecated methods
* Rename config_store to store and C template parameter to S
* Move Registration data in some inner struct

---------

Co-authored-by: Gabriel Féron <[email protected]>
  • Loading branch information
boxdot and gferon authored Nov 16, 2023
1 parent de23104 commit bdc195e
Show file tree
Hide file tree
Showing 14 changed files with 1,954 additions and 1,792 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,13 +41,13 @@ jobs:
command: build
args: --all-targets ${{ matrix.cargo_flags }}

- name: Run tests
- name: Test
uses: actions-rs/cargo@v1
with:
command: test
args: --all-targets ${{ matrix.cargo_flags }}

- name: Run doc tests
- name: Test docs
uses: actions-rs/cargo@v1
with:
command: test
Expand Down
61 changes: 34 additions & 27 deletions presage-cli/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,20 +14,23 @@ use futures::StreamExt;
use futures::{channel::oneshot, future, pin_mut};
use log::{debug, error, info};
use notify_rust::Notification;
use presage::libsignal_service::configuration::SignalServers;
use presage::libsignal_service::content::Reaction;
use presage::libsignal_service::models::Contact;
use presage::libsignal_service::prelude::phonenumber::PhoneNumber;
use presage::libsignal_service::prelude::Uuid;
use presage::libsignal_service::proto::data_message::Quote;
use presage::libsignal_service::proto::sync_message::Sent;
use presage::libsignal_service::zkgroup::GroupMasterKeyBytes;
use presage::libsignal_service::{groups_v2::Group, prelude::ProfileKey};
use presage::prelude::proto::EditMessage;
use presage::prelude::SyncMessage;
use presage::ContentTimestamp;
use presage::proto::EditMessage;
use presage::proto::SyncMessage;
use presage::store::ContentExt;
use presage::{
prelude::{
content::{Content, ContentBody, DataMessage, GroupContextV2},
Contact, SignalServers,
},
prelude::{phonenumber::PhoneNumber, Uuid},
GroupMasterKeyBytes, Manager, Registered, RegistrationOptions, Store, Thread,
libsignal_service::content::{Content, ContentBody, DataMessage, GroupContextV2},
manager::{Registered, RegistrationOptions},
store::{Store, Thread},
Manager,
};
use presage_store_sled::MigrationConflictStrategy;
use presage_store_sled::SledStore;
Expand Down Expand Up @@ -204,10 +207,10 @@ async fn main() -> anyhow::Result<()> {
run(args.subcommand, config_store).await
}

async fn send<C: Store + 'static>(
async fn send<S: Store + 'static>(
msg: &str,
uuid: &Uuid,
manager: &mut Manager<C, Registered>,
manager: &mut Manager<S, Registered>,
) -> anyhow::Result<()> {
let timestamp = std::time::SystemTime::now()
.duration_since(UNIX_EPOCH)
Expand Down Expand Up @@ -247,8 +250,8 @@ async fn send<C: Store + 'static>(

// Note to developers, this is a good example of a function you can use as a source of inspiration
// to process incoming messages.
async fn process_incoming_message<C: Store>(
manager: &mut Manager<C, Registered>,
async fn process_incoming_message<S: Store>(
manager: &mut Manager<S, Registered>,
attachments_tmp_dir: &Path,
notifications: bool,
content: &Content,
Expand Down Expand Up @@ -286,8 +289,8 @@ async fn process_incoming_message<C: Store>(
}
}

fn print_message<C: Store>(
manager: &Manager<C, Registered>,
fn print_message<S: Store>(
manager: &Manager<S, Registered>,
notifications: bool,
content: &Content,
) {
Expand Down Expand Up @@ -315,7 +318,7 @@ fn print_message<C: Store>(
}),
..
} => {
let Ok(Some(message)) = manager.message(thread, *timestamp) else {
let Ok(Some(message)) = manager.store().message(thread, *timestamp) else {
log::warn!("no message in {thread} sent at {timestamp}");
return None;
};
Expand All @@ -338,6 +341,7 @@ fn print_message<C: Store>(

let format_contact = |uuid| {
manager
.store()
.contact_by_id(uuid)
.ok()
.flatten()
Expand All @@ -348,6 +352,7 @@ fn print_message<C: Store>(

let format_group = |key| {
manager
.store()
.group(key)
.ok()
.flatten()
Expand Down Expand Up @@ -402,20 +407,20 @@ fn print_message<C: Store>(
let ts = content.timestamp();
let (prefix, body) = match msg {
Msg::Received(Thread::Contact(sender), body) => {
let contact = format_contact(sender);
let contact = format_contact(*sender);
(format!("From {contact} @ {ts}: "), body)
}
Msg::Sent(Thread::Contact(recipient), body) => {
let contact = format_contact(recipient);
let contact = format_contact(*recipient);
(format!("To {contact} @ {ts}"), body)
}
Msg::Received(Thread::Group(key), body) => {
let sender = format_contact(&content.metadata.sender.uuid);
let group = format_group(key);
let sender = format_contact(content.metadata.sender.uuid);
let group = format_group(*key);
(format!("From {sender} to group {group} @ {ts}: "), body)
}
Msg::Sent(Thread::Group(key), body) => {
let group = format_group(key);
let group = format_group(*key);
(format!("To group {group} @ {ts}"), body)
}
};
Expand All @@ -435,8 +440,8 @@ fn print_message<C: Store>(
}
}

async fn receive<C: Store>(
manager: &mut Manager<C, Registered>,
async fn receive<S: Store>(
manager: &mut Manager<S, Registered>,
notifications: bool,
) -> anyhow::Result<()> {
let attachments_tmp_dir = Builder::new().prefix("presage-attachments").tempdir()?;
Expand All @@ -459,7 +464,7 @@ async fn receive<C: Store>(
Ok(())
}

async fn run<C: Store + 'static>(subcommand: Cmd, config_store: C) -> anyhow::Result<()> {
async fn run<S: Store + 'static>(subcommand: Cmd, config_store: S) -> anyhow::Result<()> {
match subcommand {
Cmd::Register {
servers,
Expand Down Expand Up @@ -563,6 +568,7 @@ async fn run<C: Store + 'static>(subcommand: Cmd, config_store: C) -> anyhow::Re
let mut manager = Manager::load_registered(config_store).await?;
if profile_key.is_none() {
for contact in manager
.store()
.contacts()?
.filter_map(Result::ok)
.filter(|c| c.uuid == uuid)
Expand All @@ -589,7 +595,7 @@ async fn run<C: Store + 'static>(subcommand: Cmd, config_store: C) -> anyhow::Re
Cmd::UpdateContact => unimplemented!(),
Cmd::ListGroups => {
let manager = Manager::load_registered(config_store).await?;
for group in manager.groups()? {
for group in manager.store().groups()? {
match group {
Ok((
group_master_key,
Expand Down Expand Up @@ -620,7 +626,7 @@ async fn run<C: Store + 'static>(subcommand: Cmd, config_store: C) -> anyhow::Re
uuid,
phone_number,
..
} in manager.contacts()?.flatten()
} in manager.store().contacts()?.flatten()
{
println!("{uuid} / {phone_number:?} / {name}");
}
Expand All @@ -631,7 +637,7 @@ async fn run<C: Store + 'static>(subcommand: Cmd, config_store: C) -> anyhow::Re
}
Cmd::GetContact { ref uuid } => {
let manager = Manager::load_registered(config_store).await?;
match manager.contact_by_id(uuid)? {
match manager.store().contact_by_id(*uuid)? {
Some(contact) => println!("{contact:#?}"),
None => eprintln!("Could not find contact for {uuid}"),
}
Expand All @@ -643,6 +649,7 @@ async fn run<C: Store + 'static>(subcommand: Cmd, config_store: C) -> anyhow::Re
} => {
let manager = Manager::load_registered(config_store).await?;
for contact in manager
.store()
.contacts()?
.filter_map(Result::ok)
.filter(|c| uuid.map_or_else(|| true, |u| c.uuid == u))
Expand Down
2 changes: 1 addition & 1 deletion presage-store-sled/src/error.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use presage::{libsignal_service::protocol::SignalProtocolError, StoreError};
use presage::{libsignal_service::protocol::SignalProtocolError, store::StoreError};

#[derive(Debug, thiserror::Error)]
pub enum SledStoreError {
Expand Down
Loading

0 comments on commit bdc195e

Please sign in to comment.