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
- Configuration — config.yaml schema
- Plugins: Mail — Gmail / Outlook / IMAP setup
- Plugins: iMessage — chat.db permissions
- OAuth setup — Google Cloud / Azure AD recipes
- Search — FTS5 query syntax
- Contributing
- Security
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file accountpilot-0.1.2.tar.gz.
File metadata
- Download URL: accountpilot-0.1.2.tar.gz
- Upload date:
- Size: 128.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a9e1039f2f6ca1737e68bf6c8a0a09b982176e7dd7298ea3665eeaf7a1c1ca91
|
|
| MD5 |
72d8040f7460b1f41bf23b584be8091f
|
|
| BLAKE2b-256 |
44a445d16ff35d87809acc75170b2ea97d696bef5c21bafc22888cc2a2a2a56c
|
Provenance
The following attestation bundles were made for accountpilot-0.1.2.tar.gz:
Publisher:
publish.yml on aren13/accountpilot
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
accountpilot-0.1.2.tar.gz -
Subject digest:
a9e1039f2f6ca1737e68bf6c8a0a09b982176e7dd7298ea3665eeaf7a1c1ca91 - Sigstore transparency entry: 1436368424
- Sigstore integration time:
-
Permalink:
aren13/accountpilot@e81b0a4368de0da7c9b336ef85fe233834a61801 -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/aren13
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@e81b0a4368de0da7c9b336ef85fe233834a61801 -
Trigger Event:
push
-
Statement type:
File details
Details for the file accountpilot-0.1.2-py3-none-any.whl.
File metadata
- Download URL: accountpilot-0.1.2-py3-none-any.whl
- Upload date:
- Size: 103.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f935c640605143380ddbf028b26db44f832a64af3cfc88f52107780ff0755e9
|
|
| MD5 |
7aeb1c822ebcbdabfba91f2fe74a9c23
|
|
| BLAKE2b-256 |
e9451610c473dfa24e790e4ee0aada412b0a542603344447a7dddbd053febb26
|
Provenance
The following attestation bundles were made for accountpilot-0.1.2-py3-none-any.whl:
Publisher:
publish.yml on aren13/accountpilot
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
accountpilot-0.1.2-py3-none-any.whl -
Subject digest:
1f935c640605143380ddbf028b26db44f832a64af3cfc88f52107780ff0755e9 - Sigstore transparency entry: 1436368520
- Sigstore integration time:
-
Permalink:
aren13/accountpilot@e81b0a4368de0da7c9b336ef85fe233834a61801 -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/aren13
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@e81b0a4368de0da7c9b336ef85fe233834a61801 -
Trigger Event:
push
-
Statement type: