Star 历史趋势
数据来源: GitHub API · 生成自 Stargazers.cn
README.md

Photon CLI

Typed terminal UI for the Photon Dashboard. Replaces the web UI for everyday work — manage projects, Spectrum users / lines / platforms, billing, and your developer profile from a terminal.

npx @photon-ai/cli login # try it without installing npm install -g @photon-ai/cli # or install for daily use

Runs on Node.js >= 18. Bun is also supported but not required.


Install

One-off — no install

npx @photon-ai/cli login npx @photon-ai/cli projects ls

Each invocation pulls the latest release on demand. Good for scripts, throwaway machines, or trying the CLI before committing. Works with npx, pnpx, or bunx.

Global install

npm install -g @photon-ai/cli photon login

After install, both photon and the shorter pho alias are on your PATH.

Also works with other package managers:

pnpm add -g @photon-ai/cli yarn global add @photon-ai/cli bun add -g @photon-ai/cli

Standalone binary

For CI environments or systems where you don't want any runtime. Replace <os> and <arch> with your platform:

# <os>: darwin | linux <arch>: arm64 | x64 curl -L -o /usr/local/bin/photon \ https://github.com/photon-hq/cli/releases/latest/download/photon-<os>-<arch> chmod +x /usr/local/bin/photon photon --version

Available for macOS (arm64 / x64) and Linux (x64 / arm64). Each binary ships with a corresponding .sha256 checksum on the same release page.


Update

The CLI shows a notification when a new version is available. To update:

npm update -g @photon-ai/cli photon --version

Or with other package managers:

pnpm update -g @photon-ai/cli yarn global upgrade @photon-ai/cli bun update -g @photon-ai/cli

If you're using a standalone binary, re-download the latest release:

curl -L -o /usr/local/bin/photon \ https://github.com/photon-hq/cli/releases/latest/download/photon-<os>-<arch> chmod +x /usr/local/bin/photon

npx / pnpx / bunx users always get the latest release automatically — no manual update needed.

To suppress the update notification, set PHOTON_NO_UPDATE_NOTIFIER=1.


Quickstart

# 1. Log in (opens a browser to approve the device) photon login # 2. Pick a project for this shell session photon projects ls export PHOTON_PROJECT_ID=<project-id> # 3. Off you go photon projects show photon spectrum users ls photon billing show

The pho alias

pho is a shortcut for photon, useful for high-frequency commands. Every global install (npm / pnpm / yarn / bun) wires up both photon and pho automatically — they're declared as sibling bin entries that point at the same binary, so no setup is needed:

pho ls # photon projects ls pho whoami

For npx / bunx, the package name itself is what you type, so npx @photon-ai/cli runs photon (the first declared bin). To run pho explicitly through npx, use npx --package=@photon-ai/cli pho.


Concepts

Backend host

Every command talks to a backend URL. The default — and the only URL baked into the public bundle — is production (https://app.photon.codes). To target any other backend (your own deployment, a staging environment, a local dev server), set PHOTON_API_HOST:

export PHOTON_API_HOST=https://your.backend.tld photon login photon projects ls # Or one-off, per command: photon projects ls --api-host https://your.backend.tld # Or inline: PHOTON_API_HOST=https://your.backend.tld photon projects ls

Resolution order: --api-host <url> flag → PHOTON_API_HOST env var → built-in production.

photon env current prints the resolved host:

$ photon env current production (https://app.photon.codes) $ PHOTON_API_HOST=http://localhost:3000 photon env current localhost_3000 (http://localhost:3000)

Credentials are stored per host ($PHOTON_CONFIG_DIR/credentials/<key>.json by default — see config dir below — mode 600), so you can be logged into multiple backends simultaneously. The <key> is derived from the URL — production keeps the literal name production for back-compat; other hosts get a sanitized hostname where ., :, and % are replaced with _ (e.g. staging-app_photon_codes, localhost_3000). The _ substitution avoids collisions between distinct hosts like a-b.com and a.b-com.

Setting an active project

Most commands operate on a single project. Two ways to specify it:

# Per command — explicit, scoped to one invocation photon spectrum users ls --project abc123 # Per shell — set once, applies to every photon invocation in this shell export PHOTON_PROJECT_ID='abc123' photon spectrum users ls photon projects show

Resolution order: --project <id> flag → $PHOTON_PROJECT_ID → friendly error.

Put export PHOTON_PROJECT_ID='…' in your shell rc, or use direnv to scope it to a directory. Agents and scripts should pass --project <id> explicitly per call (or set the env var on the spawn).

Multi-backend note. $PHOTON_PROJECT_ID is shell-global and single-valued. If you switch PHOTON_API_HOST between backends in the same shell, prefer --project <id> for the off-default calls, or use a separate shell per backend.

CI / scripting

Authenticate once locally, copy the token from your credentials file (under $PHOTON_CONFIG_DIR/credentials/<key>.json), and use it in CI:

photon projects ls --token "$PHOTON_TOKEN" # or PHOTON_TOKEN=… photon projects ls

Pair with --json for machine-readable output:

photon projects ls --json | jq '.[] | .id' photon billing show --json

PHOTON_TOKEN reuses the same access token issued by the device flow (default 7d expiry — re-run photon login when it expires). A long-lived API-key path is on the roadmap.


Command reference

photon ├── ping hit /api/health ├── env current print resolved API host ├── login [--api-host] [--no-browser] device-auth login ├── logout [--api-host] clear creds ├── whoami [--api-host] who am I on this backend ├── auth status login state across backends ├── config show dump active config ├── projects │ ├── ls list projects │ ├── show [id] project detail │ ├── create [--name <n> --location <loc> --spectrum] new project │ ├── update [id] [...] rename / toggle flags │ ├── delete [id] [-y] permanent delete │ ├── regenerate-secret [id] [-y] rotate Spectrum secret │ ├── open [id] open dashboard in browser │ ├── upgrade [id] [tier] subscribe / open Stripe portal │ └── check-phone <number> availability check ├── profile show / init / update developer / org profile ├── spectrum │ ├── users ls / add / remove │ ├── lines ls / add / remove │ ├── platforms ls / enable / disable │ ├── profile show / update │ └── avatar upload <file> └── billing ├── plans available plans ├── show current subscription ├── checkout [tier] [--plan <price-id>] Stripe Checkout (browser) └── manage Stripe Customer Portal

Run photon <cmd> --help for the full flag list of any command.


Flags

Only --debug is truly program-level (works in any position). Every other flag is per-command and must come after the subcommand:

photon --debug projects ls --api-host https://x.tld --json # ✓ --debug global, others per-cmd photon --api-host https://x.tld projects ls # ✗ won't work (--api-host is per-cmd)
FlagEnv varScopeEffect
--debugPHOTON_DEBUG=1programverbose HTTP logs to stderr
--api-host <url>PHOTON_API_HOSTper-cmdoverride the backend URL
-p, --project <id>PHOTON_PROJECT_IDper-cmdproject id for this command; defaults to $PHOTON_PROJECT_ID
-t, --token <token>PHOTON_TOKENper-cmdbypass stored creds (CI)
--jsonper-cmdstructured output (opt-in)
--yes, -yper-cmdskip destructive-action confirmation
--no-browserper-cmddon't auto-open browser (login, billing, projects open)
--no-colorNO_COLOR=1, PHOTON_NO_COLOR=1program (env-driven)disable colors (NO_COLOR standard)

config dir

The CLI's config root is resolved in this order:

  1. $PHOTON_CONFIG_DIR (explicit override)
  2. $XDG_CONFIG_HOME/photon (XDG standard)
  3. ~/.config/photon/ (default)

If a legacy ~/.config/photon-dashboard/ directory exists from a prior pre-rename install, it migrates automatically to the new path on first run.

Other env vars: PHOTON_TYPES_SRC (maintainer-only, for bun run sync:api), PHOTON_NO_UPDATE_NOTIFIER=1 (mute update prompt).


Development

git clone https://github.com/photon-hq/cli cd cli bun install # Run from source bun run src/index.ts --help # Watch bun run dev # Typecheck bun run typecheck # Build (produces dist/photon.js) bun run build # Sync API types from a sibling `dashboard` checkout (maintainer) bun run sync:api

The CLI's API contract comes from the @photon-ai/api-public type bundle, vendored at types/api.d.ts. To refresh after the dashboard's API surface changes, run bun run sync:api (looks for the sibling checkout by default; set PHOTON_TYPES_SRC to override).

See docs/cli-design.md and docs/cli-build-plan.md for the full architecture notes.


Releases

Tagged via PR labels. Add the release label to any PR; on merge to main, the Release workflow (a thin caller of photon-hq/buildspace's typescript-service-release) generates a version + notes, bumps package.json, creates a GitHub Release, and publishes to npm. Standalone binaries are uploaded by release-binaries.yaml on each release.

关于 About

Use Photon in your terminal

语言 Languages

TypeScript99.2%
JavaScript0.8%

提交活跃度 Commit Activity

代码提交热力图
过去 52 周的开发活跃度
66
Total Commits
峰值: 24次/周
Less
More

核心贡献者 Contributors