The project is in a healthy, maintained state
Connectors for iMessage
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 3.10
~> 1.63
~> 2.3
~> 13.0

Runtime

 Project Readme

Chronicle::Imessage

Gem Version

Access your iMessage messages and attachments using the command line with this plugin for chronicle-etl.

Usage

# Install chronicle-etl and this plugin
$ gem install chronicle-etl
$ chronicle-etl plugins:install imessage

# Load messages from the last week
$ chronicle-etl --extractor imessage --schema chronicle --since 1w

# Of the latest 1000 messages received, who were the top senders?
$ chronicle-etl -e imessage --schema chronicle --limit 1000 --fields agent.name | sort | uniq -c | sort -nr

Available Connectors

Extractors

message

Extractor for importing messages and attachments from local macOS iMessage install (via local cache at ~/Library/Messages/chat.db)

Settings
  • input: (default: ~/Library/Messages/chat.db) Local iMessage sqlite database
  • load_attachments: (default: false) Whether to load message attachments
  • only_attachments: (default: false) Whether to load only messages with attachments

We want messages to have sender/receiver information set properly so we try to infer your iCloud information and phone number automatically. If these fail, you can provide the necessary information with:

  • my_phone_number: Your phone number (for setting messages's actor fields properly)
  • my_name: Your name (for setting messages's actor fields properly)
  • icloud_account_id: Specify an email address that represents your iCloud account ID
  • icloud_account_dsid: Specify iCloud DSID
    • Can find in Keychain or by running $ defaults read MobileMeAccounts Accounts