29 releases (18 stable)

2.3.0 Jan 16, 2025
2.2.2 Dec 17, 2024
2.2.1 Nov 26, 2024
1.9.0 Jun 10, 2024
0.1.4 Dec 30, 2022

#841 in Database interfaces

Download history 135/week @ 2024-10-29 153/week @ 2024-11-05 156/week @ 2024-11-12 298/week @ 2024-11-19 367/week @ 2024-11-26 308/week @ 2024-12-03 348/week @ 2024-12-10 391/week @ 2024-12-17 183/week @ 2024-12-24 190/week @ 2024-12-31 215/week @ 2025-01-07 269/week @ 2025-01-14 113/week @ 2025-01-21 125/week @ 2025-01-28 195/week @ 2025-02-04 142/week @ 2025-02-11

608 downloads per month
Used in imessage-exporter

GPL-3.0-or-later

1MB
15K SLoC

imessage-database

This library provides interfaces to interact with iMessage Databases.

Installation

This library is available on crates.io.

Documentation

Documentation is available on docs.rs.

Example

use imessage_database::{
    error::table::TableError,
    tables::{
        messages::Message,
        table::{get_connection, Table},
    },
    util::dirs::default_db_path,
};

fn iter_messages() -> Result<(), TableError> {
    /// Create a read-only connection to an iMessage database
    let db = get_connection(&default_db_path()).unwrap();

    /// Create SQL statement
    let mut statement = Message::get(&db)?;

    /// Execute statement
    let messages = statement
        .query_map([], |row| Ok(Message::from_row(row)))
        .unwrap();

    /// Iterate over each row
    for message in messages {
        let mut msg = Message::extract(message)?;

        /// Deserialize message body
        msg.generate_text(&db);

        /// Emit debug info for each message
        println!("{:?}", msg)
    }

    Ok(())
}

Dependencies

~31MB
~595K SLoC