Catalog
openai/cli-creator

openai

cli-creator

Build a composable CLI for Codex from API docs, an OpenAPI spec, existing curl examples, an SDK, a web app, an admin tool, or a local script. Use when the user wants Codex to create a command-line tool that can run from any repo, expose composable read/write commands, return stable JSON, manage auth, and pair with a companion skill.

global
0installs0uses~2.6k
v1.1Saved Apr 20, 2026

CLI Creator

Create a real CLI that future Codex threads can run by command name from any working directory.

This skill is for durable tools, not one-off scripts. If a short script in the current repo solves the task, write the script there instead.

Start

Name the target tool, its source, and the first real jobs it should do:

  • Source: API docs, OpenAPI JSON, SDK docs, curl examples, browser app, existing internal script, article, or working shell history.
  • Jobs: literal reads/writes such as list drafts, download failed job logs, search messages, upload media, read queue schedule.
  • Install name: a short binary name such as ci-logs, slack-cli, sentry-cli, or buildkite-logs.

Prefer a new folder under ~/code/clis/<tool-name> when the user wants a personal tool and has not named a repo.

Before scaffolding, check whether the proposed command already exists:

command -v <tool-name> || true

If it exists, choose a clearer install name or ask the user.

Choose the Runtime

Before choosing, inspect the user's machine and source material:

command -v cargo rustc node pnpm npm python3 uv || true

Then choose the least surprising toolchain:

  • Default to Rust for a durable CLI Codex should run from any repo: one fast binary, strong argument parsing, good JSON handling, easy copy/install into ~/.local/bin.
  • Use TypeScript/Node when the official SDK, auth helper, browser automation library, or existing repo tooling is the reason the CLI can be better.
  • Use Python when the source is data science, local file transforms, notebooks, SQLite/CSV/JSON analysis, or Python-heavy admin tooling that can still be installed as a durable command.

Do not pick a language that adds setup friction unless it materially improves the CLI. If the best language is not installed, either install the missing toolchain with the user's approval or choose the next-best installed option.

State the choice in one sentence before scaffolding, including the reason and the installed toolchain you found.

Command Contract

Sketch the command surface in chat before coding. Include the binary name, discovery commands, resolve or ID-lookup commands, read commands, write commands, raw escape hatch, auth/config choice, and PATH/install command.

When designing the command surface, read references/agent-cli-patterns.md for the expected composable CLI shape.

Build toward this surface:

  • tool-name --help shows every major capability.
  • tool-name --json doctor verifies config, auth, version, endpoint reachability, and missing setup.
  • tool-name init ... stores local config when env-only auth is painful.
  • Discovery commands find accounts, projects, workspaces, teams, queues, channels, repos, dashboards, or other top-level containers.
  • Resolve commands turn names, URLs, slugs, permalinks, customer input, or build links into stable IDs so future commands do not repeat broad searches.
  • Read commands fetch exact objects and list/search collections. Paginated lists support a bounded --limit, cursor, offset, or clearly documented default.
  • Write commands do one named action each: create, update, delete, upload, schedule, retry, comment, draft. They accept the narrowest stable resource ID, support --dry-run, draft, or preview first when the service allows it, and do not hide writes inside broad commands such as fix, debug, or auto.
  • --json returns stable machine-readable output.
  • A raw escape hatch exists: request, tool-call, api, or the nearest honest name.

Do not expose only a generic request command. Give Codex high-level verbs for the repeated jobs.

Document the JSON policy in the CLI README or equivalent: API pass-through versus CLI envelope, success shape, error shape, and one example for each command family. Under --json, errors must be machine-readable and must not contain credentials.

Auth and Config

Support the boring paths first, in this precedence order:

  1. Environment variable using the service's standard name, such as GITHUB_TOKEN.
  2. User config under ~/.<tool-name>/config.toml or another simple documented path.
  3. --api-key or a tool-specific token flag only for explicit one-off tests. Prefer env/config for normal use because flags can leak into shell history or process listings.

Never print full tokens. doctor --json should say whether a token is available, the auth source category (flag, env, config, provider default, or missing), and what setup step is missing.

If the CLI can run without network or auth, make that explicit in doctor --json: report fixture/offline mode, whether fixture data was found, and whether auth is not required for that mode.

For internal web apps sourced from DevTools curls, create sanitized endpoint notes before implementing: resource name, method/path, required headers, auth mechanism, CSRF behavior, request body, response ID fields, pagination, errors, and one redacted sample response. Never commit copied cookies, bearer tokens, customer secrets, or full production payloads.

Use screenshots to infer workflow, UI vocabulary, fields, and confirmation points. Do not treat screenshots as API evidence unless they are paired with a network request, export, docs page, or fixture.

Build Workflow

  1. Read the source just enough to inventory resources, auth, pagination, IDs, media/file flows, rate limits, and dangerous write actions. If the docs expose OpenAPI, download or inspect it before naming commands.
  2. Sketch the command list in chat. Keep names short and shell-friendly.
  3. Scaffold the CLI with a README or equivalent repo-facing instructions.
  4. Implement doctor, discovery, resolve, read commands, one narrow draft or dry-run write path if requested, and the raw escape hatch.
  5. Install the CLI on PATH so tool-name ... works outside the source folder.
  6. Smoke test from another repo or /tmp, not only with cargo run or package-manager wrappers. Run command -v <tool-name>, <tool-name> --help, and <tool-name> --json doctor.
  7. Run format, typecheck/build, unit tests for request builders, pagination/request-body builders, no-auth doctor, help output, and at least one fixture, dry-run, or live read-only API call.

If a live write is needed for confidence, ask first and make it reversible or draft-only.

When the source is an existing script or shell history, split the working invocation into real phases: setup, discovery, download/export, transform/index, draft, upload, poll, live write. Preserve the flags, paths, and environment variables the user already relies on, then wrap the repeatable phases with stable IDs, bounded JSON, and file outputs.

For raw escape hatches, support read-only calls first. Do not run raw non-GET/HEAD requests against a live service unless the user asked for that specific write.

For media, artifact, or presigned upload flows, test each phase separately: create upload, transfer bytes, poll/read processing status, then attach or reference the resulting ID.

For fixture-backed prototypes, keep fixtures in a predictable project path and make the CLI locate them after installation. Smoke-test from /tmp to catch binaries that only work inside the source folder.

For log-oriented CLIs, keep deterministic snippet extraction separate from model interpretation. Prefer a command that emits filenames, line numbers or byte ranges, matched rules, and short excerpts.

Rust Defaults

When building in Rust, use established crates instead of custom parsers:

  • clap for commands and help
  • reqwest for HTTP
  • serde / serde_json for payloads
  • toml for small config files
  • anyhow for CLI-shaped error context

Add a Makefile target such as make install-local that builds release and installs the binary into ~/.local/bin.

TypeScript/Node Defaults

When building in TypeScript/Node, keep the CLI installable as a normal command:

  • commander or cac for commands and help
  • native fetch, the official SDK, or the user's existing HTTP helper for API calls
  • zod only where external payload validation prevents real breakage
  • package.json bin entry for the installed command
  • tsup, tsx, or tsc using the repo's existing convention

Add an install path such as pnpm install, pnpm build, and pnpm link --global, or a Makefile target that installs a small wrapper into ~/.local/bin.

Python Defaults

When building in Python, prefer boring standard-library pieces unless the workflow needs more:

  • argparse for commands and help, or typer when subcommands would otherwise get messy
  • urllib.request / urllib.parse, requests, or httpx for HTTP, matching what is already installed or already used nearby
  • json, csv, sqlite3, pathlib, and subprocess for local files, exports, databases, and existing scripts
  • pyproject.toml console script or a small executable wrapper for the installed command
  • uv or a virtualenv only when dependencies are actually needed

Add a Makefile target such as make install-local that installs the command on PATH and document whether it depends on uv, a virtualenv, or only system Python.

Companion Skill

After the CLI works, create or update a small skill for it. Use $skill-creator when it is available. Use $CODEX_HOME/skills/<tool-name>/SKILL.md for a personal companion skill unless the user names a repo-local .codex/skills/... path or another skill repo.

Write the companion skill in the order a future Codex thread should use the CLI, not as a tour of every feature. Explain:

  • How to verify the installed command exists.
  • Which command to run first.
  • How auth is configured.
  • Which discovery command finds the common ID.
  • The safe read path.
  • The intended draft/write path.
  • The raw escape hatch.
  • What not to do without explicit user approval.
  • Three copy-pasteable command examples.

Keep API reference details in the CLI docs or a skill reference file. Keep the skill focused on ordering, safety, and examples future Codex threads should actually run.

Files3
3 files · 15.9 KB

Select a file to preview

Overall Score

87/100

Grade

A

Excellent

Safety

90

Quality

88

Clarity

86

Completeness

84

Summary

CLI Creator teaches an agent to build durable, composable command-line tools from API documentation, SDKs, web apps, or existing scripts. It provides a structured workflow for designing the command surface, choosing a runtime (Rust, TypeScript, or Python), implementing safe auth/config patterns, and creating a companion skill to teach future Codex threads when and how to use the CLI.

Detected Capabilities

Analyze source material (API docs, SDKs, curl examples, web apps, scripts)Choose appropriate runtime based on toolchain availability and source materialDesign command surfaces following established CLI patterns and conventionsImplement secure auth via environment variables, config files, or flagsBuild Rust CLIs using clap, reqwest, serde, and Makefile install patternsBuild TypeScript/Node CLIs using commander, package.json bin entries, and npm linkBuild Python CLIs using argparse/typer and console script entry pointsCreate companion skills to teach future Codex threads how to use the CLIScaffold discoverable commands (accounts, projects, channels, etc.)Implement read/write verbs with stable JSON output and error handlingSupport pagination with bounded limits and cursor/offset patternsTest CLIs from outside the source folder to ensure portability

Trigger Keywords

Phrases that MCP clients use to match this skill to user intent.

build command-line toolcreate cli from apicli from openapi specinstall durable binarycomposable command surfacecli with json outputauth management clicli from curl examples

Risk Signals

INFO

Instructions reference command -v checks and shell command execution for toolchain detection

SKILL.md: 'Inspect the user's machine and source material' section
INFO

Skill instructs agent to read API docs, SDKs, and web app network traffic (DevTools curls)

SKILL.md: 'Auth and Config' section and 'For internal web apps sourced from DevTools curls'
INFO

Instructs agent to create sanitized endpoint notes before committing — explicitly warns against committing cookies, tokens, secrets, and payloads

SKILL.md: 'For internal web apps sourced from DevTools curls, create sanitized endpoint notes'
INFO

Skill teaches agent to support environment variable auth following service standard names (e.g., GITHUB_TOKEN)

SKILL.md: 'Auth and Config' precedence section
INFO

Instructs agent to avoid printing full tokens and to redact credentials in error output

SKILL.md: 'Never print full tokens' and references/agent-cli-patterns.md: 'Redact tokens, cookies, customer secrets'
INFO

Skill teaches agent to prefer read-only raw escape hatches and to ask before implementing live writes

SKILL.md: 'For raw escape hatches, support read-only calls first'
INFO

Instructs agent to test CLIs from outside source folder (/tmp) to catch portability issues

SKILL.md: 'Smoke test from another repo or /tmp, not only with cargo run'
INFO

Skill guides agent to create Makefile or package.json entries for binary installation on PATH

SKILL.md: 'Rust Defaults', 'TypeScript/Node Defaults', 'Python Defaults'

Referenced Domains

External domains referenced in skill content, detected by static analysis.

www.apache.org

Use Cases

  • Build a reusable CLI from REST API documentation or OpenAPI specs
  • Convert one-off scripts or curl examples into installable, shareable commands
  • Create a tool that manages auth securely and returns stable JSON output
  • Design a composable command surface with discovery, read, and write verbs
  • Install a durable binary into PATH that Codex can invoke from any repository

Quality Notes

  • ✓ Excellent domain specificity: skill teaches a complete workflow from source analysis to installation and testing.
  • ✓ Strong security guardrails: explicitly warns against committing credentials, teaches env/config auth precedence, prohibits printing full tokens, and requires redaction of secrets in error output.
  • ✓ Clear decision tree: 'Choose the Runtime' section provides concrete criteria for selecting Rust (default), TypeScript (SDK availability), or Python (data science/transforms).
  • ✓ Well-structured build workflow: breaks CLI creation into 7 sequential phases (read source, sketch commands, scaffold, implement, install, smoke test, test).
  • ✓ Language-specific defaults: provides established crate/library recommendations for each runtime (clap, reqwest, serde for Rust; commander, zod for Node; argparse, typer for Python).
  • ✓ Comprehensive command design reference: references/agent-cli-patterns.md covers help text, command shapes, discovery/resolve/read patterns, pagination, exit codes, and raw escape hatches.
  • ✓ Auth best practices: precedence order (env → config → flags) with explicit warnings against flag-leaked credentials.
  • ✓ Portable binary validation: instructs agent to test outside source folder to catch binaries that only work in development context.
  • ✓ Companion skill guidance: teaches agent to create focused, ordered skill that explains when to use the CLI rather than documenting every feature.
  • ✓ Avoids false safety: does not warn about normal agent operations like file writes to project directories or shell commands within scoped purpose.
  • ✓ Real-world examples: shows literal command shapes (tool-name --json accounts list) and clear job descriptions (list drafts, download failed logs).
  • ✓ Media flow handling: covers multi-phase flows (create upload, transfer bytes, poll status, attach ID) tested separately.
  • ✗ Minor: No guidance on error message design (e.g., whether to include hints for common failures); scope is clear but could mention common pitfalls like forgetting config path documentation.
  • ✗ Minor: Does not explicitly address versioning strategy for installed CLIs (should users pin versions, check for updates?).
  • ✗ Minor: Fixture-backed prototypes mentioned but no detailed guidance on fixture location strategy across macOS/Linux/Windows.
Model: claude-haiku-4-5-20251001Analyzed: Apr 20, 2026

Reviews

Add this skill to your library to leave a review.

No reviews yet

Be the first to share your experience.

Version History

v1.1

Content updated

2026-04-20

Latest
v1.0

No changelog

2026-04-12

Add openai/cli-creator to your library

Command Palette

Search for a command to run...