pp-bandsintown
Turn Bandsintown's two read-only endpoints into a tour-routing brain: local cache, calendar-gap detection, lineup... Trigger phrases: `is artist X touring near jakarta`, `find routing candidates for a jakarta show`, `who's playing southeast asia in august`, `co-bills for phoenix`, `rising tracker count artists`, `use bandsintown`, `run bandsintown`.
What this skill does
<!-- GENERATED FILE — DO NOT EDIT.
This file is a verbatim mirror of library/media-and-entertainment/bandsintown/SKILL.md,
regenerated post-merge by tools/generate-skills/. Hand-edits here are
silently overwritten on the next regen. Edit the library/ source instead.
See the repository agent guide, section "Generated artifacts: registry.json, cli-skills/". -->
# Bandsintown — Printing Press CLI
## Prerequisites: Install the CLI
This skill drives the `bandsintown-pp-cli` binary. **You must verify the CLI is installed before invoking any command from this skill.** If it is missing, install it first:
1. Install via the Printing Press installer. It defaults binaries to `$HOME/.local/bin` on macOS/Linux and `%LOCALAPPDATA%\Programs\PrintingPress\bin` on Windows:
```bash
npx -y @mvanhorn/printing-press-library install bandsintown --cli-only
```
2. Verify: `bandsintown-pp-cli --version`
3. Ensure the reported install directory is on `$PATH` for the agent/runtime that will invoke this skill.
If the `npx` install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.26.3 or newer):
```bash
go install github.com/mvanhorn/printing-press-library/library/media-and-entertainment/bandsintown/cmd/bandsintown-pp-cli@latest
```
If `--version` reports "command not found" after install, the runtime cannot see the binary directory on `$PATH`. Do not proceed with skill commands until verification succeeds.
## When to Use This CLI
Reach for this CLI when a booking question depends on aggregating Bandsintown data across artists or over time — tour-routing feasibility, calendar-gap detection, co-bill patterns, tracker_count deltas. For one-off 'what shows does Phoenix have' queries, the bandsintown.com web UI is fine. For repeatable, agent-driven, multi-artist intelligence, this is the right tool.
## When Not to Use This CLI
Do not activate this CLI for requests that require creating, updating, deleting, publishing, commenting, upvoting, inviting, ordering, sending messages, booking, purchasing, or changing remote state. This printed CLI exposes read-only commands for inspection, export, sync, and analysis.
## Unique Capabilities
These capabilities aren't available in any other tool for this API.
### Routing intelligence
- **`route`** — Find which tracked artists already have shows near a target city within a date window — feasibility-ranked routing candidates for booking.
_When booking an event in a specific city, the cheapest path is finding an artist already routing through the region. Reach for this before any cold outreach._
```bash
bandsintown-pp-cli route --to "Jakarta,ID" --on 2026-08-15 --window 7d --tracked --json
```
- **`gaps`** — Find empty windows in an artist's tour calendar that match an event slot length, optionally constrained to a region.
_Use this to identify artists with a touring gap that aligns with your event date — the most actionable booking lead._
```bash
bandsintown-pp-cli gaps "Beach House" --min 5d --max 21d --in SEA --json
```
- **`sea-radar`** — One-shot Southeast Asia briefing: all upcoming shows in a date range across tracked artists, grouped by city, tagged with tracker tier.
_Monday-morning briefing in one invocation: who is touring SEA in your event window, ranked by demand._
```bash
bandsintown-pp-cli sea-radar --date 2026-08-01,2026-08-31 --tier mid --json
```
### Lineup intelligence
- **`lineup co-bill`** — Surface which artists frequently co-bill with a given artist by aggregating lineup arrays across many events.
_When building festival lineups, find natural co-bill pairings backed by real shared-stage history._
```bash
bandsintown-pp-cli lineup co-bill "Phoenix" --since 2024-01-01 --min-shared 2 --json
```
### Demand intelligence
- **`trend`** — Track tracker_count and upcoming_event_count over time per artist; surface rising and falling demand signals.
_Rising tracker_count is a leading indicator of audience demand; use to decide who to book before peers notice._
```bash
bandsintown-pp-cli trend --top 20 --period 30d --json
```
### Agent-native plumbing
- **`pull`** — Re-fetch every tracked artist's events with a staleness window; emit a structured diff (added / removed / changed events) for downstream agents.
_Run this in a daily cron; pipe the diff into Slack or a project tracker to alert when tracked artists add new shows._
```bash
bandsintown-pp-cli pull --tracked --since-stale 12 --json
```
### Local state that compounds
- **`track`** — Local watchlist of artists you care about. Drives sync, snapshot, route, and sea-radar.
_Build a curated watchlist once; every other intelligence command reads from it._
```bash
bandsintown-pp-cli track add "Phoenix" "Tame Impala" "Beach House"
```
## Command Reference
**artists** — Manage artists
- `bandsintown-pp-cli artists <artistname>` — Get artist information
**events** — Manage events
- `bandsintown-pp-cli events <artistname>` — Get upcoming, past, or all artist events, or events within a date range
### Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
```bash
bandsintown-pp-cli which "<capability in your own words>"
```
`which` resolves a natural-language capability query to the best matching command from this CLI's curated feature index. Exit code `0` means at least one match; exit code `2` means no confident match — fall back to `--help` or use a narrower query.
## Recipes
### Monday-morning SEA routing briefing
```bash
bandsintown-pp-cli sea-radar --date 2026-08-01,2026-08-31 --tier mid --json --select 'shows.city,shows.artist,shows.datetime,shows.tracker_count'
```
Print a SEA-only briefing for the August event window with only the fields you need. Run `bandsintown-pp-cli pull --tracked` first to hydrate the local store.
### Rising-demand artists this month
```bash
bandsintown-pp-cli trend --top 20 --period 30d --json
```
Compare today's tracker_count snapshot against snapshots from the last 30 days. Output the top 20 rising artists. Run `bandsintown-pp-cli snapshot` more than once over time to grow the time series.
### Festival co-bill for a candidate headliner
```bash
bandsintown-pp-cli lineup co-bill "Phoenix" --since 2024-01-01 --min-shared 2 --json
```
Surface every artist who shared a stage with Phoenix on 2+ events since 2024. Pipes cleanly into your lineup planner.
### Find a gap in an artist's calendar that fits your event
```bash
bandsintown-pp-cli gaps "Beach House" --min 5d --max 21d --in SEA --json
```
Show empty windows of 5–21 days in Beach House's SEA touring calendar — the actionable booking leads.
## Auth Setup
No authentication required.
Run `bandsintown-pp-cli doctor` to verify setup.
## Agent Mode
Add `--agent` to any command. Expands to: `--json --compact --no-input --no-color --yes`.
- **Pipeable** — JSON on stdout, errors on stderr
- **Filterable** — `--select` keeps a subset of fields. Dotted paths descend into nested structures; arrays traverse element-wise. Critical for keeping context small on verbose APIs:
```bash
bandsintown-pp-cli artists mock-value --app-id 550e8400-e29b-41d4-a716-446655440000 --agent --select id,name,status
```
- **Previewable** — `--dry-run` shows the request without sending
- **Offline-friendly** — sync/search commands can use the local SQLite store when available
- **Non-interactive** — never prompts, every input is a flag
- **Read-only** — do not use this CLI for create, update, delete, publish, comment, upvote, invite, order, send, or other mutating requests
### Response envelope
Commands that read from the local store or the API wrap output in a provenance envelope:
```json
{
"meta": {"source": "live" | "local", "synced_at": "...", "reason": "..."},
"results": <data>
}
```
Parse `.results` for data and `.meta.source` to know whether it's live or local. A human-readable `N results Related in Productivity
gitea-workflow
IncludedOrchestrate agile development workflows for Gitea repositories using the tea CLI. Use when working with Gitea-hosted repos and asking to 'run the workflow', 'continue working', 'what's next', 'complete the task cycle', 'start my day', 'end the sprint', 'implement the next task', or wanting guided step-by-step development assistance. Keywords: workflow, orchestrate, agile, task cycle, sprint, daily, implement, review, PR, standup, retrospective, gitea, tea.
microsoft-graph-gateway
IncludedRoute Microsoft Graph work in this workspace. Use when users want to read or write Outlook mail, calendar events, contacts, OneDrive or SharePoint files, Teams, Planner, To Do, users, groups, directory data, or arbitrary Microsoft Graph endpoints from VS Code. Prefer WorkIQ for common read scenarios. Use Microsoft Graph for write actions and gap-read scenarios that need exact Graph properties, filters, permissions, or endpoints.
copilotkit
IncludedUse when building with CopilotKit — setup, development, integrations, debugging, upgrading, or contributing. Routes to the appropriate specialized skill based on the task.
wordly-wisdom
IncludedProvides calibrated decision analysis using Charlie Munger-style multiple mental models, inversion, incentive mapping, circle-of-competence checks, misjudgment audits, second-order effects, and forecast updates. Use when the user asks for an oracle take, a hard call, a decision memo, a premortem, an outside view, a red-team, a sanity-check, what am I missing, think this through, or wants a strategy, hire, investment, plan, product, partnership, or major life choice analysed. Avoid for simple factual lookups or time-sensitive legal, medical, or market questions without fresh evidence.
swain-session
IncludedSession management and project status dashboard. Owns the full session lifecycle (start/work/close/resume), focus lane, bookmarks, worktree detection, and tab naming. Also serves as the project status dashboard — shows active epics, progress, actionable next steps, blocked items, tasks, GitHub issues, and recommendations. Worktree creation is deferred to swain-do task dispatch (SPEC-195). Triggers on: 'session', 'status', 'what's next', 'dashboard', 'overview', 'where are we', 'what should I work on', 'show me priorities', 'bookmark', 'focus on', 'session info'.
gandi
IncludedComprehensive Gandi domain registrar integration for domain and DNS management. Register and manage domains, create/update/delete DNS records (A, AAAA, CNAME, MX, TXT, SRV, and more), configure email forwarding and aliases, check SSL certificate status, create DNS snapshots for safe rollback, bulk update zone files, and monitor domain expiration. Supports multi-domain management, zone file import/export, and automated DNS backups. Includes both read-only and destructive operations with safety controls.