Skip to content

[Parity] Edge Config CLI (vercel edge-config)#15822

Merged
brookemosby merged 10 commits into
mainfrom
brooke/cli-parity-edge-config
Apr 6, 2026
Merged

[Parity] Edge Config CLI (vercel edge-config)#15822
brookemosby merged 10 commits into
mainfrom
brooke/cli-parity-edge-config

Conversation

@brookemosby

Copy link
Copy Markdown
Contributor

Summary

Adds vercel edge-config with dashboard API parity for Edge Config stores (team scope):

  • list (ls) — GET /v1/edge-config
  • add (create) — POST /v1/edge-config (optional --items JSON object)
  • get (inspect) — GET /v1/edge-config/:id (accepts ecfg_… id or slug)
  • updatePUT slug rename and/or PATCH items via --patch (JSON array or { "items": [...] })
  • remove (rm, delete) — DELETE /v1/edge-config/:id (confirmation / --yes)
  • itemsGET all items or one via --key
  • tokens — list GET, create POST (--add <label>), revoke DELETE (--remove, repeatable; --yes in non-interactive)

Non-interactive / agents

  • exitWithNonInteractiveError supports variant edge-config: API 404 maps to not_found (not project_not_found), with next[] pointing at edge-config list, teams switch, whoami.

Testing

  • pnpm exec vitest run test/unit/commands/edge-config/edge-config.test.ts (from packages/cli)

Changeset

  • Minor bump for vercel CLI package (.changeset/cli-edge-config.md).

Closes / tracks parity issue: Edge Config CLI (attach to your internal parity issue as needed).

Made with Cursor

- Add edge-config list, add, get, update, remove, items, tokens subcommands
- Wire /v1/edge-config APIs with team scope and slug-or-id resolution
- Extend exitWithNonInteractiveError with edge-config variant (404 -> not_found)
- Add unit tests and changeset

Made-with: Cursor
@brookemosby brookemosby requested review from a team as code owners April 2, 2026 22:30
@changeset-bot

changeset-bot Bot commented Apr 2, 2026

Copy link
Copy Markdown

🦋 Changeset detected

Latest commit: 34a2182

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 1 package
Name Type
vercel Minor

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@vercel

vercel Bot commented Apr 2, 2026

Copy link
Copy Markdown
Contributor

Low Risk — New CLI command feature with CRUD operations, telemetry, and tests — no auth/schema/billing changes.

  • .changeset/cli-edge-config.md: minor bump for new vercel edge-config command
  • packages/cli/src/commands/edge-config/: new subcommands (list, add, get, update, remove, items, tokens) with telemetry
  • packages/cli/src/util/agent-output.ts: added edge-config variant for non-interactive error handling

Assessed at 34a2182.

Comment thread packages/cli/src/commands/edge-config/update.ts Outdated
Resolve agent-output: keep edge-config next steps and hints; extend
ExitWithNonInteractiveErrorVariant with access-summary and web-analytics.

Made-with: Cursor
@github-actions

github-actions Bot commented Apr 3, 2026

Copy link
Copy Markdown
Contributor

🧪 Unit Test Strategy

Comparing: c16413534a2182 (view diff)

Strategy: Affected packages only

✅ Only testing packages that have been modified or depend on modified packages.

Affected packages - 1 (3%)
  1. vercel
Unaffected packages - 39 (98%)
  1. @vercel-internals/get-package-json
  2. @vercel/backends
  3. @vercel/build-utils
  4. @vercel/cervel
  5. @vercel/cli-auth
  6. @vercel/client
  7. @vercel/config
  8. @vercel/detect-agent
  9. @vercel/edge
  10. @vercel/elysia
  11. @vercel/error-utils
  12. @vercel/express
  13. @vercel/fastify
  14. @vercel/firewall
  15. @vercel/frameworks
  16. @vercel/fs-detectors
  17. @vercel/functions
  18. @vercel/gatsby-plugin-vercel-builder
  19. @vercel/go
  20. @vercel/h3
  21. @vercel/hono
  22. @vercel/hydrogen
  23. @vercel/koa
  24. @vercel/nestjs
  25. @vercel/next
  26. @vercel/node
  27. @vercel/oidc
  28. @vercel/oidc-aws-credentials-provider
  29. @vercel/python
  30. @vercel/python-analysis
  31. @vercel/redwood
  32. @vercel/related-projects
  33. @vercel/remix-builder
  34. @vercel/routing-utils
  35. @vercel/ruby
  36. @vercel/rust
  37. @vercel/static-build
  38. @vercel/static-config
  39. examples

Results

  • Unit tests: Only affected packages will run unit tests
  • E2E tests: Running in parallel via E2E Tests workflow
  • Type checks: Only affected packages will run type checks

This comment is automatically generated based on the affected testing strategy

- Extract parse-patch-body and normalize \r\n, \n, \t before JSON.parse
- Document required operation field in --patch help text

Made-with: Cursor
Resolve agent-output: keep edge-config + ProjectExitWithNonInteractiveVariant;
add speed-insights to ExitWithNonInteractiveErrorVariant (main).

Made-with: Cursor
…--help snapshot

- Add edge-config to expected commands map in index.test.ts
- Use stderr getFullOutput() instead of read() for dev --help snapshot so the
  captured output matches across platforms (read() can differ on Linux CI)

Made-with: Cursor
@github-actions

github-actions Bot commented Apr 6, 2026

Copy link
Copy Markdown
Contributor

📦 CLI Tarball Ready

The Vercel CLI tarball for this PR is now available!

Quick Test

You can test this PR's CLI directly by running:

npx https://vercel-d8ms2jue4.vercel.sh/tarballs/vercel.tgz --help

Use in vercel.json

To use this CLI version in your project builds, add to your vercel.json:

{
  "build": {
    "env": {
      "VERCEL_CLI_VERSION": "vercel@https://vercel-d8ms2jue4.vercel.sh/tarballs/vercel.tgz"
    }
  }
}

Python Runtime Wheel

A vercel-runtime wheel was also built for this PR.
To use in your Python project builds, also set this environment variable:

VERCEL_RUNTIME_PYTHON="vercel-runtime @ https://vercel-d8ms2jue4.vercel.sh/tarballs/vercel_runtime-0.13.0.dev1775496162+1e9f5e5-py3-none-any.whl"

Python Workers Wheel

A vercel-workers wheel was also built for this PR.
To use in your Python project builds, also set this environment variable:

VERCEL_WORKERS_PYTHON="vercel-workers @ https://vercel-d8ms2jue4.vercel.sh/tarballs/vercel_workers-0.1.0.dev1775496162+1e9f5e5-py3-none-any.whl"

parsePatchBody now runs before any API calls so invalid --patch cannot
leave the store renamed after a failed validation.

Adds a unit test that asserts PUT is not called when patch validation fails.

Made-with: Cursor
@brookemosby brookemosby enabled auto-merge (squash) April 6, 2026 18:32
@brookemosby brookemosby merged commit 9f2ec51 into main Apr 6, 2026
300 of 302 checks passed
@brookemosby brookemosby deleted the brooke/cli-parity-edge-config branch April 6, 2026 18:37
nsidnev pushed a commit that referenced this pull request Apr 7, 2026
## Summary
Adds `vercel edge-config` with dashboard API parity for Edge Config
stores (team scope):

- **list** (`ls`) — `GET /v1/edge-config`
- **add** (`create`) — `POST /v1/edge-config` (optional `--items` JSON
object)
- **get** (`inspect`) — `GET /v1/edge-config/:id` (accepts `ecfg_…` id
or slug)
- **update** — `PUT` slug rename and/or `PATCH` items via `--patch`
(JSON array or `{ "items": [...] }`)
- **remove** (`rm`, `delete`) — `DELETE /v1/edge-config/:id`
(confirmation / `--yes`)
- **items** — `GET` all items or one via `--key`
- **tokens** — list `GET`, create `POST` (`--add <label>`), revoke
`DELETE` (`--remove`, repeatable; `--yes` in non-interactive)

## Non-interactive / agents
- `exitWithNonInteractiveError` supports variant `edge-config`: API
**404** maps to `not_found` (not `project_not_found`), with `next[]`
pointing at `edge-config list`, `teams switch`, `whoami`.

## Testing
- `pnpm exec vitest run
test/unit/commands/edge-config/edge-config.test.ts` (from
`packages/cli`)

## Changeset
- Minor bump for `vercel` CLI package (`.changeset/cli-edge-config.md`).

Closes / tracks parity issue: **Edge Config CLI** (attach to your
internal parity issue as needed).

Made with [Cursor](https://cursor.com)
healeycodes pushed a commit that referenced this pull request Apr 7, 2026
This PR was opened by the [Changesets
release](https://github.com/changesets/action) GitHub action. When
you're ready to do a release, you can merge this and the packages will
be published to npm automatically. If you're not ready to do a release
yet, that's fine, whenever you add more changesets to main, this PR will
be updated.


# Releases
## @vercel/build-utils@13.13.0

### Minor Changes

- Extend `finalizeLambda` with pluggable ZIP strategy (`createZip`),
pre-digest validation hook (`validateZip`), and optional trace tags.
Widen `getLambdaEnvironment` buffer param to `{ byteLength: number }`.
([#15856](#15856))

## vercel@50.41.0

### Minor Changes

- Add `vercel edge-config` with `list`, `add`, `get`, `update`,
`remove`, `items`, and `tokens` subcommands for Edge Config dashboard
API parity. ([#15822](#15822))

- Add `vercel project checks` to list a project's deployment checks
configuration (parity with dashboard), including `--format json` and
non-interactive error payloads.
([#15816](#15816))

### Patch Changes

- Improve `vercel teams request` in non-interactive mode: validation,
missing team scope, and API errors emit structured JSON on stdout with
stable `reason` values and `next[]` commands that preserve global flags
(for example `--cwd` and `--non-interactive`).
([#15815](#15815))

- Hide `--search` flag from `vc logs --help` output while continuing to
accept it, and update the `--query` flag description to indicate
advanced querying with filter syntax support.
([#15854](#15854))

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0
    -   @vercel/backends@0.0.56
    -   @vercel/elysia@0.1.59
    -   @vercel/express@0.1.69
    -   @vercel/fastify@0.1.62
    -   @vercel/go@3.4.7
    -   @vercel/h3@0.1.68
    -   @vercel/hono@0.2.62
    -   @vercel/hydrogen@1.3.6
    -   @vercel/koa@0.1.42
    -   @vercel/nestjs@0.2.63
    -   @vercel/next@4.16.5
    -   @vercel/node@5.7.1
    -   @vercel/python@6.29.0
    -   @vercel/redwood@2.4.12
    -   @vercel/remix-builder@5.7.2
    -   @vercel/ruby@2.3.2
    -   @vercel/rust@1.0.6
    -   @vercel/static-build@2.9.9

## @vercel/backends@0.0.56

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/cervel@0.0.43

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/backends@0.0.56

## @vercel/client@17.2.68

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/elysia@0.1.59

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/express@0.1.69

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1
    -   @vercel/cervel@0.0.43

## @vercel/fastify@0.1.62

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/fs-detectors@5.14.3

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/gatsby-plugin-vercel-builder@2.1.9

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/h3@0.1.68

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/hono@0.2.62

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/koa@0.1.42

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/nestjs@0.2.63

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/node@5.7.1

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/static-build@2.9.9

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/gatsby-plugin-vercel-builder@2.1.9

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
blurrah pushed a commit that referenced this pull request Apr 8, 2026
This PR was opened by the [Changesets
release](https://github.com/changesets/action) GitHub action. When
you're ready to do a release, you can merge this and the packages will
be published to npm automatically. If you're not ready to do a release
yet, that's fine, whenever you add more changesets to main, this PR will
be updated.


# Releases
## @vercel/build-utils@13.13.0

### Minor Changes

- Extend `finalizeLambda` with pluggable ZIP strategy (`createZip`),
pre-digest validation hook (`validateZip`), and optional trace tags.
Widen `getLambdaEnvironment` buffer param to `{ byteLength: number }`.
([#15856](#15856))

## vercel@50.41.0

### Minor Changes

- Add `vercel edge-config` with `list`, `add`, `get`, `update`,
`remove`, `items`, and `tokens` subcommands for Edge Config dashboard
API parity. ([#15822](#15822))

- Add `vercel project checks` to list a project's deployment checks
configuration (parity with dashboard), including `--format json` and
non-interactive error payloads.
([#15816](#15816))

### Patch Changes

- Improve `vercel teams request` in non-interactive mode: validation,
missing team scope, and API errors emit structured JSON on stdout with
stable `reason` values and `next[]` commands that preserve global flags
(for example `--cwd` and `--non-interactive`).
([#15815](#15815))

- Hide `--search` flag from `vc logs --help` output while continuing to
accept it, and update the `--query` flag description to indicate
advanced querying with filter syntax support.
([#15854](#15854))

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0
    -   @vercel/backends@0.0.56
    -   @vercel/elysia@0.1.59
    -   @vercel/express@0.1.69
    -   @vercel/fastify@0.1.62
    -   @vercel/go@3.4.7
    -   @vercel/h3@0.1.68
    -   @vercel/hono@0.2.62
    -   @vercel/hydrogen@1.3.6
    -   @vercel/koa@0.1.42
    -   @vercel/nestjs@0.2.63
    -   @vercel/next@4.16.5
    -   @vercel/node@5.7.1
    -   @vercel/python@6.29.0
    -   @vercel/redwood@2.4.12
    -   @vercel/remix-builder@5.7.2
    -   @vercel/ruby@2.3.2
    -   @vercel/rust@1.0.6
    -   @vercel/static-build@2.9.9

## @vercel/backends@0.0.56

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/cervel@0.0.43

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/backends@0.0.56

## @vercel/client@17.2.68

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/elysia@0.1.59

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/express@0.1.69

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1
    -   @vercel/cervel@0.0.43

## @vercel/fastify@0.1.62

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/fs-detectors@5.14.3

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/gatsby-plugin-vercel-builder@2.1.9

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/h3@0.1.68

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/hono@0.2.62

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/koa@0.1.42

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/nestjs@0.2.63

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.7.1

## @vercel/node@5.7.1

### Patch Changes

- Updated dependencies
\[[`a80217a9ed60d7b7f3e98537b0468cc5488078c1`](a80217a)]:
    -   @vercel/build-utils@13.13.0

## @vercel/static-build@2.9.9

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/gatsby-plugin-vercel-builder@2.1.9

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants