CLI tool for GitHub/Forgejo community awareness β tracking notifications, logging activity, managing escalations.
Named after Argus Panoptes, the all-seeing giant of Greek mythology.
- Notification triage β Pull, act, or dismiss GitHub notifications
- Activity logging β Track community actions
- Escalation management β Flag and track issues needing attention
- Dashboard β Visual overview via Datasette + static HTML
- Systemd service β Run in background
# Install
./scripts/install.sh
# Initialize database
argus init
# Set up authentication (choose one)
gh auth login # GitHub
export ARGUS_BACKEND=tea # Forgejo (needs tea token with read:notification)
# Pull notifications
argus notif pull
# Check status
argus status
# Start dashboard
systemctl enable --now argusFor AI agents using OpenClaw, add this to your HEARTBEAT.md for periodic community awareness:
### Argus Community Awareness (Daily)
1. **Check status**: `argus status`
2. **Pull notifications**: `argus notif pull`
3. **Review pending**: `argus notif list --pending --limit 5`
4. **Triage**: For each pending notification:
- If actionable: `argus notif act <id> <action> "<detail>"`
- If not relevant: `argus notif dismiss <id> "<reason>"`
5. **Audit stale**: `argus notif audit --stale-hours 48`
6. **Log activity**: Record significant actions with `argus activity log`
7. **Check escalations**: `argus escalate list --status open`The install script outputs this block β just copy it to your HEARTBEAT.md.
make test| Command | Description |
|---|---|
argus init |
Create database |
argus version |
Show version |
argus status |
Summary overview |
| Command | Description |
|---|---|
argus repo list |
List watched repositories |
argus repo watch <owner/repo> |
Subscribe to a repository |
argus repo unwatch <owner/repo> |
Unsubscribe from a repository |
| Command | Description |
|---|---|
argus notif pull [--backend gh|tea] |
Fetch from GitHub/Forgejo |
argus notif list [--pending] |
List notifications |
argus notif act <id> <action> |
Mark as acted |
argus notif dismiss <id> [reason] |
Dismiss |
argus notif audit |
Auto-escalate stale |
| Command | Description |
|---|---|
argus activity log <action> <detail> |
Log action |
argus activity list |
Show recent |
| Command | Description |
|---|---|
argus escalate create --category --title |
Create |
argus escalate list [--status] |
List |
argus escalate ack <id> |
Acknowledge |
argus escalate resolve <id> --by --resolution |
Resolve |
| Command | Description |
|---|---|
argus serve |
Start Datasette + dashboard |
Environment variables:
| Variable | Default | Description |
|---|---|---|
ARGUS_DB |
~/.argus/argus.db |
Database path |
ARGUS_PORT |
8100 |
Dashboard port (datasette runs on port+1) |
ARGUS_BACKEND |
gh |
Backend: gh (GitHub) or tea (Forgejo) |
GH_TOKEN |
β | GitHub API token (for gh backend) |
βββββββββββββββββββββββββββββββββββββββββββββββββββ
β argus CLI β
β notif pull | activity log | escalate | serve β
βββββββββββββββββββ¬ββββββββββββββββββββββββββββββββ
β
βΌ
βββββββββββββββββββββββββββββββββββββββββββββββββββ
β ~/.argus/argus.db β
β repos | issues | notifications | activity β
βββββββββββββββββββ¬ββββββββββββββββββββββββββββββββ
β
βββββββββββ΄ββββββββββ
βΌ βΌ
βββββββββββββββββ βββββββββββββββββ
β Dashboard β β Datasette β
β :PORT (HTML) β β :PORT+1 (API) β
βββββββββββββββββ βββββββββββββββββ
Default: Dashboard on 8100, Datasette on 8101. Set ARGUS_PORT to change base port.
- Python 3.9+
- pip
- gh CLI (for GitHub integration)
git clone https://forgejo.tail593e12.ts.net/Zeus/argus.git /opt/argus
cd /opt/argus && ./scripts/install.sh/opt/argus/scripts/uninstall.shsystemctl enable argus # Start on boot
systemctl start argus # Start now
systemctl status argus # Check status
journalctl -u argus -f # View logsMIT