Travel assistant for NanoClaw: byAir flight notifications (delay, gate, connection risk, inbound aircraft delay, time-to-leave, arrival logistics), travel-booking gap checks, and nightly TripIt sync. Per-chat overlay tile.
75
93%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Advisory
Suggest reviewing before use
Actionable travel assistance for NanoClaw — byAir-powered flight notifications, travel-booking gap checks, and nightly TripIt sync. Replaces generic "21 minutes to departure" reminders with alerts that change behavior. Powered by byAir for flight data and Google Maps Distance Matrix for traffic-aware time-to-leave.
Per-chat overlay tile. Install via NanoClaw's containerConfig.additionalTiles mechanism.
tessl install jbaruch/nanoclaw-travelAdd to a chat's overlay tile list via update_group_config:
additionalTiles: ["jbaruch/nanoclaw-travel"]| Variable | Purpose | Where to get |
|---|---|---|
BYAIR_MCP_URL | byAir streamable-HTTP MCP endpoint (includes API key) | https://byairapp.com/mcp/ — Pro subscription, personal MCP link |
GOOGLE_MAPS_API_KEY | Distance Matrix API key for time-to-leave | https://console.cloud.google.com/apis/credentials |
Store both in OneCLI vault. Never commit. See .env.example for the contract; GitHub Actions secrets configuration link is in its file header.
| Rule | Summary |
|---|---|
| flight-data-locality | byAir is the single upstream for flight data; AeroAPI / Flighty / airline-specific APIs forbidden |
| operator-local-tz-phrasing | Relative-date words ("today"/"tomorrow") in a surface are phrased against the operator's local date (via read-current-tz.py), not the container UTC clock; displayed airport clock times stay as-is |
| Skill | Description |
|---|---|
| flight-assist | Action router: diagnose credentials, set home base, or compose a user-facing notification from a precheck wake event (delay, gate change, cancellation, boarding, time-to-leave, carousel, day-before, arrival logistics, tracked-flight add/remove) |
| sync-tripit | Adaptive scheduler that fires the byAir → active-flights.json refresh on a precheck-gated 5-min cadence — responsive on flight days, idle between travel windows. Diagnostic-only LLM surface (the gate + sync happen in the precheck script) |
| check-travel-bookings | Checks upcoming trips for missing bookings (flights, hotels, accommodation) by reading the nightly-built travel-db.json. Reports gaps for all upcoming trips — no date limit. Supports snooze state. Silent when all bookings are complete or snoozed. Use when the user asks about upcoming travel plans, itinerary completeness, missing reservations, or TripIt trip status. |
| nightly-travel-sync | Daily travel-data refresh bundle: TripIt → Reclaim timezone sync, refresh travel-schedule.json from the TripIt iCal feed with a two-tier Gmail freshness probe, rebuild travel-db.json, then run check-travel-bookings. Precheck-gated on travel-db.json freshness; surfaces failures and relies on the daily cron + freshness probe to recover. Self-contained writer of the data check-travel-bookings reads. |
The skill bundle includes executable scripts the agent invokes via the SKILL.md actions:
scripts/check-env.py — verifies BYAIR_MCP_URL + GOOGLE_MAPS_API_KEY are setscripts/set-home-base.py — persists home address to tile config for time-to-leave queriesscripts/get-flight-state.py — fetches a flight's last-known snapshot to enrich notificationsscripts/read-current-tz.py — resolves the operator's current_tz from tz_state so surfaces phrase relative dates in the operator's local zone (see operator-local-tz-phrasing rule)Plus scheduler-invoked scripts (not user-facing):
flight-assist/precheck.py — runs every ~2 min, polls byAir per cadence ladder, emits wake eventssync-tripit/precheck.py — runs every 5 min, adaptive-gated; delegates to flight-assist/sync_tripit.py only when a flight is imminent or the index is stale (see the sync-tripit skill for gate predicate + thresholds)flight-assist/sync_tripit.py — the byAir → state reconciliation invoked by the sync-tripit schedulernightly-travel-sync/precheck.py — runs daily, gates the travel-data refresh on travel-db.json freshness (see the nightly-travel-sync skill + precheck.py for the cadence predicate)nightly-travel-sync/scripts/refresh-travel-schedule.py, check-travel-freshness.py, filter-tripit-bookings.py — the travel-source writers + freshness probe the bundle drivesconnection_at_risk events when the transfer window falls below min_transfer_minutes (configurable, default 45). State schema bumped to v2 with owner-side migrationbyair_list_tripsSee CHANGELOG.md for version history.