Skip to main content

Personal AI assistant toolkit — sync, schedule, identity

Project description

aya

Personal AI assistant toolkit.

aya is a CLI tool that AI hosts call — sync context between instances, schedule reminders, and manage identity. The workspace (your guild repo) defines how your AI host behaves; aya is the tool it uses.

Why "aya"?

Och, ye might well ask. It started life as assistant-sync — perfectly descriptive, perfectly dull, the kind o' name a committee'd be proud of. Then came helm, which sounded braw and nautical until some wee Kubernetes chart showed up and said "Naw, that's mine."

So there we were, rootin' around for a name, and someone muttered "aya" — and that was that. In the Scots tongue, aya is what ye say when somethin' lands just right. Not a grand "YES" mind ye, more a quiet "aye, that'll do." The kind o' sound a canny person makes when the kettle's found, the fire's lit, and everything's settled where it ought tae be.

That's this tool. Nae fuss. Nae ceremony. Just quietly doin' the job.

Install

# From PyPI (after first release)
uvx aya

# From GitHub — works today, no PyPI required
uvx --from git+https://github.com/shawnoster/aya aya

# From source
git clone https://github.com/shawnoster/aya.git
cd aya
uv sync

Quick start

# Set up identity
uv run aya init --label work

# Pair with another machine
uv run aya pair --label work        # shows a code
uv run aya pair --code WORD-WORD-0000 --label home  # on the other machine

# Send a packet
echo "Hello from work" | uv run aya pack --to home --intent "test" | uv run aya send /dev/stdin

# Check inbox
uv run aya inbox

Scheduling

aya has its own scheduler, but Claude Code also has a separate cloud-based automation system called CCR (Claude Code Remote). They solve different problems — knowing which to reach for saves a lot of friction.

The one question

Does this task need me, or just need to be done?

If you need to be informed or make a decision → aya schedule. If it can be completed without you → CCR remote trigger.

aya schedule — human in the loop

aya's scheduler runs on your machine. Alerts are delivered at session start via the SessionStart hook — they surface to you in your session context. You read them, decide, act.

Use aya for:

What Example
Reminders aya schedule remind "review PRs" --due 2h
Movement / wellness nudges Recurring micro-prompts injected each session
Watch and tell me "Watch PR #50 — alert me when it's approved"
Ticket state changes "Tell me when JIRA-123 moves to In Review"
Anything requiring your judgment CI is red, inbox has 10 packets, standup in 15min

aya watches poll for state and produce alerts. You are the actor.

CCR — human out of the loop

CCR (Claude Code Remote) runs isolated agents in Anthropic's cloud on a cron schedule. The agent clones your repo, does work, and exits — whether you're online or not. Use the schedule skill in Claude Code to create triggers.

Use CCR for:

What Example
PR feedback bot Address review comments, push, reply to threads
Dependency updates Weekly: open a PR bumping outdated packages
CI failure → ticket Open a bug issue when main goes red
Stale PR cleanup Comment on PRs idle >2 weeks
Nightly health report Post a repo summary to Slack
Auto-merge Merge approved PRs with passing checks
Release notes draft Weekly: summarize merged PRs into a draft
Triage Label and assign new issues by content

CCR agents act autonomously. If you want to hear about what they did, wire them to Slack or Gmail via MCP connectors in the trigger.

Choosing between them

Does it need my attention or judgment?
  Yes → aya schedule (watch / remind)

Can it be completed without me?
  Yes → CCR trigger

Does it need to run more often than hourly?
  Yes → aya schedule (any interval via system cron)

Does it need my local files or environment?
  Yes → aya schedule + SessionStart hook

CCR minimum interval is 1 hour. aya can fire at any cron interval.


One-prompt setup

Already have aya installed on another machine? Give Claude Code this prompt on the new machine and it will handle everything:

Install aya (uv tool install aya-ai-assist), initialize identity with aya init --label <LABEL> (use "home" or "work"), then pair with my other instance. If I have a pairing code from the other machine, run aya pair --code <CODE> --label <OTHER_LABEL> --instance <LABEL> and we're done. If not, run aya pair --label <OTHER_LABEL> --instance <LABEL> — this will block waiting for the other machine to join (up to 10 minutes), so give me the short code it displays and immediately run aya pair --code <CODE> on the other machine before the window expires. After pairing, set up Claude Code hooks by adding the aya SessionStart and PostToolUse hooks to ~/.claude/settings.json (see AGENTS.md for a full example). Finally, register a relay poll cron: aya schedule recurring -m "relay-poll" -c "*/10 * * * *" -p "Run: aya receive --instance <LABEL> --auto-ingest --quiet. If any packets were ingested, surface their content to the user.". Verify everything works with aya status.

Replace <LABEL> with this machine's role (home or work), <OTHER_LABEL> with the other machine's role, and <CODE> with the pairing code.

What that prompt does

  1. Installs aya globally via uv
  2. Creates identity — generates ed25519 + secp256k1 keypairs
  3. Pairs instances — exchanges trust via short-lived relay code
  4. Wires Claude Code hooks — session start receives packets, registers crons, surfaces alerts; post-tool-use watches CI
  5. Registers relay polling — checks for incoming packets every 10 minutes during active sessions

Agent integration (Claude Code)

aya is designed to surface alerts and reminders into your agent session, not just on the terminal. One command sets up everything:

aya schedule install          # crontab + Claude Code hooks
aya schedule install --dry-run  # preview first

This installs:

  • A system crontab entry (*/5 * * * *) for background polling (watches, reminders, claim sweeping)
  • Claude Code hooks for session activity tracking, cron registration, packet receiving, and CI monitoring

To remove everything: aya schedule uninstall.

What the hooks do

Hook Event What it does
aya schedule activity SessionStart, PreToolUse Resets the idle back-off timer so session crons aren't suppressed
aya hook crons SessionStart Reads pending session crons, injects CronCreate instructions into session context
aya receive --quiet --auto-ingest SessionStart Ingests packets from trusted senders in the background
aya schedule pending --format text SessionStart Prints due reminders and alerts directly into the session
aya ci watch PostToolUse (Bash) After git push, monitors CI and wakes agent if checks fail

How session crons work

aya hook crons is the bridge between aya's persistent scheduler and Claude Code's in-session cron system. On each session start it:

  1. Fetches active session-required recurring items (without claiming alerts)
  2. Filters by idle back-off and work-hours constraints
  3. Outputs a hookSpecificOutput.additionalContext block with explicit CronCreate instructions

The agent reads those instructions and must call CronCreate for each cron before responding. This registers recurring jobs for the session — so a */15 * * * * PR watch fires automatically every 15 minutes without the user having to ask.

Registering a session cron

# Watch a PR — fires every 15 min, Mon–Fri
aya schedule recurring \
  --message "pr123-merge-watch" \
  --cron "*/15 * * * 1-5" \
  --prompt "Check PR #123. If merged, watch staging deploy and notify."

The cron is persisted in aya's scheduler store. On the next session start, aya hook crons picks it up and injects the CronCreate call automatically.

PostToolUse: CI watch

After every shell command, aya can watch any triggered CI workflows to completion:

{
  "matcher": "Bash",
  "command": "aya ci watch 2>/dev/null || true",
  "asyncRewake": true
}

After a git push, aya monitors triggered GitHub Actions workflows and wakes the agent if a check fails.

Non-Claude-Code agents

If your host doesn't support hooks, run this manually at the top of each session:

aya schedule pending --format text

This prints all due reminders, alerts, and session cron prompts as plain text. Copy any session cron prompts into your context to pick them up.


Commands

Command What it does
aya version Show the installed aya version
aya init Generate identity keypair for this instance
aya profile Initialize or rotate the persistent assistant profile
aya pair Pair two instances via short-lived relay code
aya trust Manually trust a DID
aya pack Create a signed knowledge packet
aya send Publish a packet to a Nostr relay
aya dispatch Pack + send in one step (no temp file)
aya inbox List pending packets
aya receive Review and ingest packets
aya status Workspace readiness check — systems, schedule, focus
aya ci CI integration — watch checks, report failures
aya schedule remind Add a one-shot reminder
aya schedule watch Add a polling watch (GitHub PR, Jira ticket/query)
aya schedule recurring Add a persistent recurring session job
aya schedule activity Record user activity — resets the idle back-off timer
aya schedule is-idle Check whether the session is currently idle
aya schedule list List scheduled items
aya schedule check Check for due reminders and alerts
aya schedule dismiss Dismiss a scheduled item or alert
aya schedule snooze Snooze a reminder
aya schedule alerts Show alerts from background watcher
aya schedule tick One scheduler cycle — poll watches, expire alerts
aya schedule pending Show unclaimed alerts + session crons (SessionStart hook)
aya schedule install Install scheduler integrations — system crontab + Claude Code hooks
aya schedule uninstall Remove scheduler integrations
aya schedule status Scheduler overview — watches, reminders, deliveries

How it works

  • Identity: did:key (ed25519) for packet signing + secp256k1 for Nostr transport
  • Transport: Nostr relays (NIP-01, kind 5999) — async, federated, self-hostable
  • Packets: Signed JSON envelopes with markdown content, TTL, and conflict strategies
  • Security: Signature verification, user approval before ingest, trust registry

License

MIT

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

aya_ai_assist-1.2.0.tar.gz (128.6 kB view details)

Uploaded Source

Built Distribution

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

aya_ai_assist-1.2.0-py3-none-any.whl (54.9 kB view details)

Uploaded Python 3

File details

Details for the file aya_ai_assist-1.2.0.tar.gz.

File metadata

  • Download URL: aya_ai_assist-1.2.0.tar.gz
  • Upload date:
  • Size: 128.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aya_ai_assist-1.2.0.tar.gz
Algorithm Hash digest
SHA256 d4e5d1b486e5221480d5be5ed04613b9e40bb992c0020b0e582ff987a2b21a71
MD5 4b499411ac7f8c1944799749a728e004
BLAKE2b-256 b5f75e0f0ab0937eae33e713d5e9e7c60721d90a2675dbd827ff1dbed8d4309c

See more details on using hashes here.

Provenance

The following attestation bundles were made for aya_ai_assist-1.2.0.tar.gz:

Publisher: release.yml on shawnoster/aya

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

File details

Details for the file aya_ai_assist-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: aya_ai_assist-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 54.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aya_ai_assist-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8c1c313212a0a8648cde8cf5aef16a0b022539b0f3cefa86e3dee14dba725b96
MD5 18969f7b866abb5017ca321cff8e3d2b
BLAKE2b-256 88b897ae20eddaef0d09a73ae34c1a42ae7f6f2dccdf3672f2fd31768e412cdb

See more details on using hashes here.

Provenance

The following attestation bundles were made for aya_ai_assist-1.2.0-py3-none-any.whl:

Publisher: release.yml on shawnoster/aya

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