Skip to main content

Unified per-machine account sync framework — email, iMessage, calendar, and more

Project description

AccountPilot

A unified per-machine account sync framework. Pulls email, iMessage, calendar, and other personal data into a local SQLite database via a plugin architecture. Designed for individual users who want a queryable archive of their own data.

Features

  • Mail (IMAP IDLE): Gmail + Outlook + generic IMAP, OAuth2 (XOAUTH2) or password auth, RFC 2047 + MIME attachment handling, multi-account.
  • iMessage: macOS chat.db reader with watchdog file-watcher, attachment + group-chat support, attributedBody decoder.
  • Cross-source identity: one phone number = one person whether it appears in iMessage handles or Gmail signatures.
  • SQLite + FTS5 full-text search across every source.
  • Auto-restarting background daemon via launchd (macOS) or systemd (Linux) — install with one command.

Installation

Homebrew (macOS / Linuxbrew):

brew install aren13/tap/accountpilot

pip:

pip install accountpilot

pipx (recommended for CLI-only use, isolates dependencies):

pipx install accountpilot

Requires Python 3.11+. macOS or Linux. (iMessage support is macOS-only; mail works on both.)

Quick start

# Create the config skeleton
accountpilot setup

# Edit ~/.config/accountpilot/config.yaml to add your accounts
$EDITOR ~/.config/accountpilot/config.yaml

# For OAuth-based accounts (recommended): set up Google Cloud Console /
# Azure AD OAuth client JSON, then run the interactive login:
accountpilot oauth login google 1
accountpilot oauth login microsoft 2

# One-shot historical pull:
accountpilot mail backfill 1
accountpilot imessage backfill 2

# Install the auto-restarting background daemon:
accountpilot service install mail
accountpilot service install imessage

# Search across all sources:
accountpilot search 'invoice'
accountpilot search '"meeting tomorrow"'

Configuration

~/.config/accountpilot/config.yaml defines the people you sync FOR (owners) and the accounts you sync FROM. See docs/configuration.md for the full schema.

Documentation

License

AGPL-3.0-or-later. See LICENSE.

The AGPL'ed copy of aioimaplib (an upstream dependency) means AccountPilot ships under AGPL too. If you build a network service that exposes AccountPilot's functionality to end users, you must publish your modifications under AGPL — see the LICENSE file.

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

accountpilot-0.1.3.tar.gz (131.8 kB view details)

Uploaded Source

Built Distribution

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

accountpilot-0.1.3-py3-none-any.whl (106.0 kB view details)

Uploaded Python 3

File details

Details for the file accountpilot-0.1.3.tar.gz.

File metadata

  • Download URL: accountpilot-0.1.3.tar.gz
  • Upload date:
  • Size: 131.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for accountpilot-0.1.3.tar.gz
Algorithm Hash digest
SHA256 48b330f3374268c2f47674dcb0e6ec93a83c92eb21ada80bc47403abf4cd5cb1
MD5 7b8d0136968f75c5c6ad0e8cbbc39f9e
BLAKE2b-256 dd2e449fcbb57aa055e0bcff59c10edb17ef920b47304ede6ca6fb0199ae3150

See more details on using hashes here.

Provenance

The following attestation bundles were made for accountpilot-0.1.3.tar.gz:

Publisher: publish.yml on aren13/accountpilot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file accountpilot-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: accountpilot-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 106.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for accountpilot-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 bf48ff6b513b5d78ca4f594c3d1fc1f6ac5e1fda3e2116261850079e8edee537
MD5 7d44a5aba3a38fcab4d900e6d5ea6491
BLAKE2b-256 b6e8204f5fbb24a36954ea8ba547e64132d2869181dbe3c01659909687255e97

See more details on using hashes here.

Provenance

The following attestation bundles were made for accountpilot-0.1.3-py3-none-any.whl:

Publisher: publish.yml on aren13/accountpilot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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