WhatsApp-first LLM bot
Project description
faltoobot
faltoobot is a personal assistant that lives on its own WhatsApp account.
How it works
- Get a separate SIM / WhatsApp account for Faltoobot.
- Sign in to that account on a spare phone.
- Install
faltooboton a computer that will stay online. - Run
faltoobot updateonce after install to create~/.faltoobot/config.toml. - Edit
~/.faltoobot/config.tomlif you need to change defaults. - Run
faltoobot codex-loginto sign in with Codex / ChatGPT OAuth, or setopenai.api_keyin config. - Run
faltoobot whatsappto keep the bot running. - Message that WhatsApp number from your own number.
Install
uv tool install faltoobot
Then run the setup/update step once:
faltoobot update
This creates ~/.faltoobot/config.toml with defaults. You can run faltoobot update again later to upgrade Faltoobot and run migrations.
Then you can run faltoobot and faltoochat from any folder.
If uv asks you to add its tool bin directory to your PATH, run:
uv tool update-shell
For faster project and code search inside faltoochat, install ripgrep (rg) too:
# macOS
brew install ripgrep
# Ubuntu / Debian
sudo apt-get update && sudo apt-get install -y ripgrep
# Fedora
sudo dnf install ripgrep
# Arch Linux
sudo pacman -S ripgrep
faltoochat falls back without rg, but search is faster and more reliable when it is installed.
Quick start
1. Update and configure
faltoobot update
This creates ~/.faltoobot/config.toml with defaults. Edit that file directly whenever you need to change settings.
For Codex / ChatGPT OAuth, run:
faltoobot codex-login
Or set openai.api_key in ~/.faltoobot/config.toml.
Example config:
[openai]
api_key = "your_key_here"
oauth = ""
model = "gpt-5.5"
thinking = "high"
fast = false
websocket = true
[bot]
allow_group_chats = ["120363000000000000@g.us"]
allowed_chats = ["15551234567"]
bot_name = "Faltoo"
If oauth is set, Faltoobot prefers that OAuth auth file over api_key. If oauth is blank, Faltoobot falls back to OPENAI_API_KEY from the environment.
By default, websocket = true uses the Responses API WebSocket mode for lower-latency tool loops with either an API key or ChatGPT/Codex OAuth. Set it to false to use normal HTTP streaming.
Set allowed_chats to the WhatsApp phone numbers that should be allowed to it in direct chats. Use WhatsApp phone numbers or JIDs. Faltoobot normalizes phone numbers into WhatsApp JIDs when saving the config.
Set allow_group_chats to the group JIDs that the bot should keep history for and reply in. If a non-approved group mentions the bot, Faltoobot DMs allowed_chats with /approve_group <group_jid> and /deny_group <group_jid> instructions. In groups with more than two people, the bot replies only when mentioned or when someone replies to the bot.
2. Start WhatsApp service
faltoobot whatsapp
This is the main command for running Faltoobot. It:
- upgrades the installed tool with uv
- ensures config exists
- runs migrations
- stops any old Faltoobot service
- installs the service
- starts the service
- follows logs in the current terminal
Press Ctrl+C any time. The service keeps running in the background.
3. Watch logs later
faltoobot logs
Commands
faltoobot update
faltoobot update
Upgrades the installed tool with uv, ensures config exists, and runs migrations.
If uv installs a newer version, Faltoobot asks you to rerun the command so the rest of the flow continues with the newer installed version.
faltoobot whatsapp
faltoobot whatsapp
Best command for normal use. It runs update, refreshes the background service, and follows logs.
faltoobot logs
faltoobot logs
Shows log output in follow mode.
faltoobot codex-login
faltoobot codex-login
Signs in with Codex / ChatGPT OAuth and saves the auth file path in ~/.faltoobot/config.toml.
To change other settings, edit ~/.faltoobot/config.toml directly.
Terminal chat
You can also use Faltoobot locally in the terminal.
Interactive mode
Run faltoochat with no prompt to open the terminal UI:
faltoochat
faltoochat --workspace=./repo
faltoochat --new-session
One-shot mode
Run faltoochat with a prompt to execute a headless one-shot task in that workspace and print the final output to stdout:
faltoochat "draft a release note"
faltoochat "review unstaged files" --workspace=./repo --new-session
Notify another chat
A one-shot faltoochat run can send its final output back to another chat key. This is useful for sub-agents, cron jobs, and detached background tasks:
faltoochat "List new emails for the user" --workspace=./emails --notify-chat-key=code@main
Commands inside chat
On WhatsApp:
/help
/reset
/status
In terminal chat:
/reset
/status
/tree
faltoochat supports image input, queued prompts while answering, and Shift+Enter for multiline input. Paste an image file path or use Ctrl+V to attach the current macOS clipboard image. WhatsApp chats now also support incoming image messages, including captioned images, image-only prompts, and multi-image albums.
Development
Run the Astro docs site locally:
cd website
npm install
npm run dev
Build the static site locally:
cd website
npm run build
Tests
Run the full test suite with coverage:
uv run pytest -n auto --cov=faltoobot --cov-report=term-missing:skip-covered
Coverage is published in the badge above, and pre-commit enforces a minimum of 78% line coverage.
Need more details? See docs/cli.md and the Astro docs site in website/.
Project details
Release history Release notifications | RSS feed
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 faltoobot-6.5.0.tar.gz.
File metadata
- Download URL: faltoobot-6.5.0.tar.gz
- Upload date:
- Size: 194.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
073add80b7a9e05099584e4617dfa72876142eee35e75c1445a41da69c2b587a
|
|
| MD5 |
9637c62bb341b14673baee6d31a923dd
|
|
| BLAKE2b-256 |
462135dfbf9c62574e6485e95d7b4989bb897bb08c6bb388f512845a773f0b51
|
File details
Details for the file faltoobot-6.5.0-py3-none-any.whl.
File metadata
- Download URL: faltoobot-6.5.0-py3-none-any.whl
- Upload date:
- Size: 151.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2c3dcbc085e9aa7acaec89f8b41a68cbb376169ebac7b0f8b80f789be5041967
|
|
| MD5 |
e5b5e9928cf4f392e5f5691aaa1986c1
|
|
| BLAKE2b-256 |
25265909114d6c0a7e49b33ba97ad79fdfdd15b7ac5a97b6a9094e1586dafa08
|