Skip to main content

Fetch recipients and chat messages from the chat.db database.

Project description

imessage_reader

This is a forensic tool written in Python 3. Use this tool to fetch the content (phone numbers, email addresses, messages and the account) from the chat.db database file on macOS (version 10.14 or above).

The following information is currently being read from the database:

  • user id (sender's or recipient's phone number or email address)
  • message
  • date and time
  • service (iMessage or SMS)
  • account (destination caller id)
  • is the message from me

Background

Received messages (iMessage or SMS) and attachments will be saved in "~/Library/Messages". This directory contains a "chat.db" file (SQLite3) with two tables of interest: handle and message. The handle table contains the recipients (email address or phone number). The received messages are in the message table.

Note

Of course, the chat.db file is only created under macOS. Nevertheless, this program can also be used under Linux. In contrast to use under macOS, the path to the chat.db file must then be specified (see below).

Requirements

  • Python 3.9+
  • openpyxl

To run tests install pytest:

pip3 install pytest

Install

pip3 install imessage-reader

Usage (CLI)

Specify no options

Start the program with:

imessage_reader

This will show you all users and messages in the Terminal. If no option (-p <PATH>) is specified, the default directory (under macOS) is searched for the chat.db file.

Specify a PATH as argument

A different path to chat.db file can be specified with the -p option:

imessage_reader -p <PATH>

Unless the -o option is also used, the data is displayed in the Terminal.

Specify an output argument

You can create an Excel file containing users, messages, date and service (SMS or iMessage). The file will be stored in the Documents folder:

imessage_reader -o e

or

imessage_reader -o excel

You can create a SQLite3 database containing users, messages, date and service (SMS or iMessage). The file will be stored in the Documents folder:

imessage_reader -o s

or

imessage_reader -o sqlite

If you only want to see a list of recipients use:

imessage_reader -r

or

imessage_reader --recipients

Note: On macOS you need access to the Library folder in order to read the iMessage database file ("chat.db"). You can add access (for Terminal or iTerm) in

> System Preferences > Security & Privacy > Privacy > Full Disk Access

Specify a PATH and an output argument

You can combine the -p with the -o option:

imessage_reader -p /home/bodo/Downloads -o excel

In this example the chat.db file is located in the Downloads folder (on a Linux machine). And the Excel file will be created in the Documents folder.

Usage (import module)

To get the messages use following code:

from imessage_reader import fetch_data

DB_PATH = /home/bodo/Downloads/chat.db

# Create a FetchData instance
fd = fetch_data.FetchData(DB_PATH)

# Store messages in my_data
# This is a list of tuples containing user id, message and service (iMessage or SMS).
my_data = fd.get_messages()
print(my_data)

ToDo

  • Get the date of messages
  • Fetch the date of received messages.
  • Show a list of all known recipients.
  • Did the user receive the message via SMS or via iMessage?
  • Create SQLite3 database.
  • Specify a different path to the chat.db file.
  • Show attachments.
  • Add more tests.

Changelog

see CHANGELOG.rst

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

imessage_reader-0.6.1.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

imessage_reader-0.6.1-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file imessage_reader-0.6.1.tar.gz.

File metadata

  • Download URL: imessage_reader-0.6.1.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for imessage_reader-0.6.1.tar.gz
Algorithm Hash digest
SHA256 d9461e390d3d648d2b4c4940f7c469f02c169fc4de9d44871ebfddbb23a0a99b
MD5 76150fbf258eeb911cfa06e778c178f7
BLAKE2b-256 724d0b717ae7d0bacbedef74e40b545dcd92d153bf3bdea182562f18238cce72

See more details on using hashes here.

File details

Details for the file imessage_reader-0.6.1-py3-none-any.whl.

File metadata

File hashes

Hashes for imessage_reader-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 49f9576f08be9f798db28dd79e05b74e9d65851809233b3281eef3439b3fdca4
MD5 6f3f35cc49a90141bd79bf207d3f9efa
BLAKE2b-256 a69d25134b58f751b9d5c259d5fddca0680cabfcda3aa6b1f2e20635f144f2ef

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page