pp-seats-aero

Compare original and translation side by side

🇺🇸

Original

English
🇨🇳

Translation

Chinese

Seats Aero — Printing Press CLI

Seats Aero — Printing Press CLI工具

Prerequisites: Install the CLI

前提条件:安装CLI

This skill drives the
seats-aero-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:
    bash
    npx -y @mvanhorn/printing-press install seats-aero --cli-only
  2. Verify:
    seats-aero-pp-cli --version
  3. Ensure
    $GOPATH/bin
    (or
    $HOME/go/bin
    ) is on
    $PATH
    .
If the
npx
install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.23+):
bash
go install github.com/mvanhorn/printing-press-library/library/travel/seats-aero/cmd/seats-aero-pp-cli@latest
If
--version
reports "command not found" after install, the install step did not put the binary on
$PATH
. Do not proceed with skill commands until verification succeeds.
本技能驱动
seats-aero-pp-cli
二进制文件。在调用本技能的任何命令之前,必须确认CLI已安装。如果未安装,请先执行以下步骤:
  1. 通过Printing Press安装程序安装:
    bash
    npx -y @mvanhorn/printing-press install seats-aero --cli-only
  2. 验证安装:
    seats-aero-pp-cli --version
  3. 确保
    $GOPATH/bin
    (或
    $HOME/go/bin
    )已添加到
    $PATH
    环境变量中。
如果
npx
安装失败(如无Node环境、离线等),可改用Go直接安装(要求Go 1.23及以上版本):
bash
go install github.com/mvanhorn/printing-press-library/library/travel/seats-aero/cmd/seats-aero-pp-cli@latest
如果安装后执行
--version
提示“command not found”,说明安装程序未将二进制文件添加到
$PATH
中。请在验证成功前不要执行技能命令。

When Not to Use This CLI

何时不应使用此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.
请勿针对需要创建、更新、删除、发布、评论、点赞、邀请、下单、发送消息、预订、购买或修改远程状态的请求激活此CLI。本CLI仅提供用于查看、导出、同步和分析的只读命令。

Command Reference

命令参考

availability — Manage availability
  • seats-aero-pp-cli availability
    — Retrieve bulk availability for all tracked routes in a mileage program.
routes — Manage routes
  • seats-aero-pp-cli routes
    — Get all origin-destination routes tracked for a mileage program.
seats-aero-partner-search — Manage seats aero partner search
  • seats-aero-pp-cli seats-aero-partner-search
    — Search Seats.aero cached award availability between an origin and destination.
trips — Manage trips
  • seats-aero-pp-cli trips <id>
    — Get detailed trip information by revalidation/trip ID from search or availability results.
availability — 管理可用性
  • seats-aero-pp-cli availability
    — 获取常旅客计划中所有追踪航线的批量可用性数据。
routes — 管理航线
  • seats-aero-pp-cli routes
    — 获取常旅客计划中追踪的所有出发地-目的地航线。
seats-aero-partner-search — 管理Seats.aero合作伙伴搜索
  • seats-aero-pp-cli seats-aero-partner-search
    — 搜索Seats.aero缓存的出发地与目的地之间的奖励机票可用性。
trips — 管理行程
  • seats-aero-pp-cli trips <id>
    — 根据搜索或可用性结果中的重新验证/行程ID获取详细行程信息。

Finding the right command

查找合适的命令

When you know what you want to do but not which command does it, ask the CLI directly:
bash
seats-aero-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.
当你知道要执行的操作但不确定对应命令时,可直接询问CLI:
bash
seats-aero-pp-cli which "<用你自己的语言描述功能>"
which
命令会将自然语言的功能查询解析为与CLI精选功能索引最匹配的命令。退出码
0
表示至少找到一个匹配项;退出码
2
表示无匹配项——此时可改用
--help
或缩小查询范围。

Auth Setup

身份验证设置

Set your API key via environment variable:
bash
export SEATS_AERO_API_KEY="***"
SEATS_AERO_PARTNER_PARTNER_AUTHORIZATION
is also supported for generator compatibility. Or persist it in
~/.config/seats-aero-pp-cli/config.toml
.
Run
seats-aero-pp-cli doctor
to verify setup.
通过环境变量设置你的API密钥:
bash
export SEATS_AERO_API_KEY="***"
同时支持
SEATS_AERO_PARTNER_PARTNER_AUTHORIZATION
以兼容生成器。也可将密钥持久化存储在
~/.config/seats-aero-pp-cli/config.toml
文件中。
执行
seats-aero-pp-cli doctor
验证设置是否正确。

Agent Mode

Agent模式

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
    seats-aero-pp-cli routes --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
在任何命令后添加
--agent
参数。该参数等价于:
--json --compact --no-input --no-color --yes
  • 可管道传输 — 标准输出为JSON格式,错误信息输出到标准错误流
  • 可过滤
    --select
    参数保留指定字段子集。点路径可深入嵌套结构;数组会遍历每个元素。对于输出冗长的API,此功能对缩小上下文范围至关重要:
    bash
    seats-aero-pp-cli routes --agent --select id,name,status
  • 可预览
    --dry-run
    参数显示请求内容但不发送
  • 离线友好 — 同步/搜索命令在本地SQLite存储可用时可使用该存储
  • 非交互式 — 从不弹出提示,所有输入均通过标志参数提供
  • 只读 — 请勿使用此CLI执行创建、更新、删除、发布、评论、点赞、邀请、下单、发送或其他变更状态的请求

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 (live)
summary is printed to stderr only when stdout is a terminal — piped/agent consumers get pure JSON on stdout.
从本地存储或API读取数据的命令会将输出包裹在来源信封中:
json
{
  "meta": {"source": "live" | "local", "synced_at": "...", "reason": "..."},
  "results": <data>
}
解析
.results
获取数据,通过
.meta.source
判断数据来自实时API还是本地存储。仅当标准输出为终端时,才会将人类可读的
N results (live)
摘要输出到标准错误流;管道传输或Agent消费时,标准输出仅为纯JSON格式。

Agent Feedback

Agent反馈

When you (or the agent) notice something off about this CLI, record it:
seats-aero-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
seats-aero-pp-cli feedback --stdin < notes.txt
seats-aero-pp-cli feedback list --json --limit 10
Entries are stored locally at
~/.seats-aero-pp-cli/feedback.jsonl
. They are never POSTed unless
SEATS_AERO_FEEDBACK_ENDPOINT
is set AND either
--send
is passed or
SEATS_AERO_FEEDBACK_AUTO_SEND=true
. Default behavior is local-only.
Write what surprised you, not a bug report. Short, specific, one line: that is the part that compounds.
当你(或Agent)发现此CLI存在问题时,可记录反馈:
seats-aero-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
seats-aero-pp-cli feedback --stdin < notes.txt
seats-aero-pp-cli feedback list --json --limit 10
反馈条目存储在本地
~/.seats-aero-pp-cli/feedback.jsonl
文件中。除非设置了
SEATS_AERO_FEEDBACK_ENDPOINT
且传递了
--send
参数或设置
SEATS_AERO_FEEDBACK_AUTO_SEND=true
,否则反馈不会被POST发送。默认行为仅存储在本地。
请记录让你感到意外的内容,而非正式的错误报告。简短、具体、单行描述:这样的反馈更有价值。

Output Delivery

输出交付

Every command accepts
--deliver <sink>
. The output goes to the named sink in addition to (or instead of) stdout, so agents can route command results without hand-piping. Three sinks are supported:
SinkEffect
stdout
Default; write to stdout only
file:<path>
Atomically write output to
<path>
(tmp + rename)
webhook:<url>
POST the output body to the URL (
application/json
or
application/x-ndjson
when
--compact
)
Unknown schemes are refused with a structured error naming the supported set. Webhook failures return non-zero and log the URL + HTTP status on stderr.
每个命令都支持
--deliver <sink>
参数。输出会除了(或代替)标准输出外,发送到指定的sink,以便Agent无需手动管道即可路由命令结果。支持三种sink:
Sink效果
stdout
默认值;仅写入标准输出
file:<path>
原子性地将输出写入
<path>
(先写入临时文件再重命名)
webhook:<url>
将输出体POST到指定URL(当使用
--compact
时为
application/json
application/x-ndjson
格式)
未知的协议会被拒绝,并返回结构化错误信息说明支持的协议类型。Webhook请求失败时返回非零退出码,并将URL和HTTP状态记录到标准错误流。

Named Profiles

命名配置文件

A profile is a saved set of flag values, reused across invocations. Use it when a scheduled agent calls the same command every run with the same configuration - HeyGen's "Beacon" pattern.
seats-aero-pp-cli profile save briefing --json
seats-aero-pp-cli --profile briefing routes
seats-aero-pp-cli profile list --json
seats-aero-pp-cli profile show briefing
seats-aero-pp-cli profile delete briefing --yes
Explicit flags always win over profile values; profile values win over defaults.
agent-context
lists all available profiles under
available_profiles
so introspecting agents discover them at runtime.
配置文件是一组保存的标志值,可在多次调用中复用。当定时Agent每次运行都使用相同配置调用同一命令时,可使用此功能——即HeyGen的“Beacon”模式。
seats-aero-pp-cli profile save briefing --json
seats-aero-pp-cli --profile briefing routes
seats-aero-pp-cli profile list --json
seats-aero-pp-cli profile show briefing
seats-aero-pp-cli profile delete briefing --yes
显式指定的标志参数优先级始终高于配置文件中的值;配置文件中的值优先级高于默认值。
agent-context
会在
available_profiles
下列出所有可用配置文件,以便自省Agent在运行时发现它们。

Exit Codes

退出码

CodeMeaning
0Success
2Usage error (wrong arguments)
3Resource not found
4Authentication required
5API error (upstream issue)
7Rate limited (wait and retry)
10Config error
代码含义
0成功
2使用错误(参数错误)
3资源未找到
4需要身份验证
5API错误(上游问题)
7请求受限(请等待后重试)
10配置错误

Argument Parsing

参数解析

Parse
$ARGUMENTS
:
  1. Empty,
    help
    , or
    --help
    → show
    seats-aero-pp-cli --help
    output
  2. Starts with
    install
    → ends with
    mcp
    → MCP installation; otherwise → see Prerequisites above
  3. Anything else → Direct Use (execute as CLI command with
    --agent
    )
解析
$ARGUMENTS
的规则:
  1. 为空、
    help
    --help
    → 显示
    seats-aero-pp-cli --help
    输出
  2. install
    开头
    → 若以
    mcp
    结尾 → 安装MCP服务器;否则 → 参见上方的前提条件部分
  3. 其他情况 → 直接使用(添加
    --agent
    标志执行CLI命令)

MCP Server Installation

MCP服务器安装

  1. Install the MCP server:
    bash
    go install github.com/mvanhorn/printing-press-library/library/travel/seats-aero/cmd/seats-aero-pp-mcp@latest
  2. Register with Claude Code:
    bash
    claude mcp add seats-aero-pp-mcp -- seats-aero-pp-mcp
  3. Verify:
    claude mcp list
  1. 安装MCP服务器:
    bash
    go install github.com/mvanhorn/printing-press-library/library/travel/seats-aero/cmd/seats-aero-pp-mcp@latest
  2. 注册到Claude Code:
    bash
    claude mcp add seats-aero-pp-mcp -- seats-aero-pp-mcp
  3. 验证:
    claude mcp list

Direct Use

直接使用

  1. Check if installed:
    which seats-aero-pp-cli
    If not found, offer to install (see Prerequisites at the top of this skill).
  2. Match the user query to the best command from the Unique Capabilities and Command Reference above.
  3. Execute with the
    --agent
    flag:
    bash
    seats-aero-pp-cli <command> [subcommand] [args] --agent
  4. If ambiguous, drill into subcommand help:
    seats-aero-pp-cli <command> --help
    .
  1. 检查是否已安装:
    which seats-aero-pp-cli
    若未找到,可提供安装选项(参见顶部前提条件部分)。
  2. 将用户查询与上述独特功能和命令参考中的最佳命令匹配。
  3. 添加
    --agent
    标志执行命令:
    bash
    seats-aero-pp-cli <command> [subcommand] [args] --agent
  4. 若存在歧义,查看子命令帮助:
    seats-aero-pp-cli <command> --help