Skip to main content

Export and analyze iMessage conversations from macOS SQLite database

Project description

iMessage Wrapped

Export and analyze your iMessage conversations from the macOS SQLite database.

image image

Quick Start

🖥️ Desktop App (No Terminal Required!)

Download for macOS

  1. Download and open iMessage-Wrapped.dmg
  2. Drag to Applications folder
  3. Launch the app
  4. Click "Analyze My Messages"
  5. Your wrapped opens in browser automatically

See desktop/ for building from source.

💻 Command Line

pip install imessage-wrapped
imexport

That's it! By default, the command will:

  1. 🔄 Auto-export your messages (if not already exported)
  2. 📊 Analyze your messaging patterns
  3. ☁️ Upload anonymized statistics
  4. 🔗 Give you a shareable URL like: https://imessage-wrapped.fly.dev/2025/abc123xyz

Want to see full details in the terminal instead? Use imexport --no-share

Features

Dashboard - Interactive visualizations of your messaging patterns
Easy Sharing - One command to upload and get a shareable link
Secure - HTTPS, encrypted database
Favorite Phrases - Automatically surfaces the sayings you repeat most
Deploy Anywhere - Fly.io ready (free tier available)

🔒 Data Privacy

Your message content NEVER leaves your computer.

By default, we only upload aggregated statistics to create your shareable link. Here's exactly what is and isn't uploaded:

✅ What IS Uploaded (Statistics Only)

  • Counts: Total messages sent/received, tapbacks given/received, attachments, etc.
  • Averages: Message length, response times, punctuation usage
  • Distributions: Hour of day, day of week, month patterns
  • Emojis: Which emojis you used and how often
  • Dates: Your busiest messaging days, streak lengths
  • Anonymized Identifiers: Contact identifiers are SHA256-hashed (e.g., phone_a3b2c1d4e5f6)

❌ What is NOT Uploaded (Stays Private)

  • Message Text: No actual message content is ever sent
  • Contact Names: All names are stripped out before upload
  • Phone Numbers/Emails: Original identifiers are one-way hashed
  • Conversation Content: No snippets, samples, or quotes
  • Attachments: No photos, videos, or file content
  • Personal Info: Nothing that could identify you or your contacts

Usage

As a Library

from imessage_wrapped import MessageService, Exporter

service = MessageService()
data = service.export_year(2025)

exporter = Exporter()
exporter.export_to_file(data, "messages_2025.json")

See example_usage.py for a complete working example.

As a CLI

After installation, use the imexport command:

# Analyze and share (default behavior)
imexport

# Analyze with full terminal output (no sharing)
imexport --no-share

# Export specific year
imexport --year 2024

# Replace cached export
imexport --replace-cache

# Use local dev server
imexport --dev

# Custom database path
imexport --database /path/to/test/chat.db

# Save statistics to file
imexport --output stats.json

# Show help
imexport --help

Alternatively, run without installation:

python -m imessage_wrapped --year 2024

Requirements

  • Python 3.10+
  • macOS with Full Disk Access permission
  • rich library for terminal output

Installation

From PyPI

pip install imessage-wrapped
imexport

From Source (Development)

git clone https://github.com/gtarpenning/imessage-wrapped.git
cd imessage-wrapped
pip install -e .

# Install git hooks (recommended for contributors)
./scripts/install-git-hooks.sh

Git Hooks:

  • pre-commit: Automatically runs linting and type checking on staged Python/web files
  • pre-push: Validates that the web build compiles before pushing to main

macOS Permissions

Requires Full Disk Access to read the iMessage database:

  1. Open System Settings
  2. Go to Privacy & Security → Full Disk Access
  3. Add Terminal (for CLI) or the Desktop App
  4. Restart the application

Deployment

See RELEASE-GUIDE.md for deploying the CLI, Desktop App, or Web App.

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_wrapped-0.1.19.tar.gz (51.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

imessage_wrapped-0.1.19-py3-none-any.whl (57.3 kB view details)

Uploaded Python 3

File details

Details for the file imessage_wrapped-0.1.19.tar.gz.

File metadata

  • Download URL: imessage_wrapped-0.1.19.tar.gz
  • Upload date:
  • Size: 51.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.4

File hashes

Hashes for imessage_wrapped-0.1.19.tar.gz
Algorithm Hash digest
SHA256 ea9a5c76878a9fee8b0bbd0ede2a98666226c48f78b335c507a0c6536f63bab5
MD5 585c0b4f01ff9c17b1d282a643d92a09
BLAKE2b-256 a62aacb5bda13491e7c726cf1db257cd2926d12f525202875c68f4f9e2bc234e

See more details on using hashes here.

File details

Details for the file imessage_wrapped-0.1.19-py3-none-any.whl.

File metadata

File hashes

Hashes for imessage_wrapped-0.1.19-py3-none-any.whl
Algorithm Hash digest
SHA256 b7f0f3066bcae2e40a733720a85629cd9f0fbea0d89663891e1e5c70dbf70620
MD5 2e57eafd4e21ba0d899b39dbdf299a5c
BLAKE2b-256 3e8d3c58b7bac3621f9c804d794156f598a019dc201ceebc6c7818c88c027151

See more details on using hashes here.

Supported by

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