An open-source CLI tool for managing dynamic configuration repositories, with a focus on JSON files, on a per-project basis. It is built to pull, push, diff, list, and revert config files across distributed environments, and is ideal for systems where configurations are dynamic and need to be maintainable, versioned, and auditable. It can be plugged into larger automation pipelines as an upstream source of configuration data.
Corev-CLI is not a "plug-and-play" tool. It only works if there is an API that follows the API specification.
It uses this API topull
andpush
config files. Without it, the CLI does nothing.
npm i -g @corev/cli
Corev-CLI provides a small set of core commands to help get things done. Configuration files stored
in the configs/
folder for quick and offline access.
Action | Description |
---|---|
init |
Set the API endpoint used by the CLI |
pull |
Fetch the latest config for a project |
push |
Upload a local config file to the server |
diff |
Show differences between two config versions |
list |
List all available config versions by filename |
revert |
Revert the remote configuration to a previous version |
checkout |
Fetch a specific config version for a project and save it locally |
env |
Create an environment folder under configs//env/ |
You can configure the CLI using any of the following options:
corev init
This will prompt you to choose between using the hosted Corev API or your own custom endpoint. If you select hosted, you will also be asked to enter your API token.
corev init --host
This prompts you to enter your Corev Host API endpoint (e.g., https://your-corev-instance.com
)
and an API secret token.
You can also provide the token inline:
corev init --host --token abc123
corev init --api http://localhost:3000
You may also save a token manually:
corev init --api http://localhost:3000 --token abc123
corev init --token abc123
This only saves a new token into .corevrc.json and does not change your current API endpoint.
All configuration is saved to
.corevrc.json
in your project root.
corev pull <project>
corev push <path>
The <path>
argument can be relative or absolute, such as:
corev push configs/atlas@1.0.0.json
corev push ./staging@2.3.1.json
corev push ~/Desktop/demo@0.9.2.json
The folder structure (e.g.,
configs/
,~/Desktop/
) can be arbitrary.
corev diff configs/<project>@<version>.json configs/<project>@<version>.json
corev list
corev revert <project> <version>
corev checkout <project> <version>
corev env <project> <env>
You can pull, push, and revert configs for a specific environment using the --env
flag.
corev pull atlas --env staging
This will save the file to:
configs/atlas/env/staging/atlas@<version>.json
corev push configs/atlas/env/staging/atlas@1.0.0.json --env staging
corev revert atlas 1.0.0 --env staging
This allows you to manage parallel configurations per environment (
dev
,staging
,test
, etc.) while preserving version control.
Implementers SHOULD provide the endpoints listed below so Corev-CLI can perform
pull
andpush
operations correctly.
HTTP Method | Endpoint URL | Description |
---|---|---|
GET | /configs/:project/latest |
Returns the latest configuration |
GET | /configs/:project/:version |
Returns a specific configuration by version |
POST | /configs/:project |
Uploads a new or updated configuration |
In addition to method and endpoint matching, the Corev CLI uses custom headers to indicate the context of the operation:
Header Name | Example Value | Description |
---|---|---|
x-corev-action |
push / revert |
Describes the action type: "push" , "revert" , etc. |
x-corev-secret |
abcdef12345 |
Token used for authentication (set via corev init ) |
x-corev-env |
staging |
(Optional) Indicates which environment the operation targets; defaults to "production" if omitted |
These headers MUST be supported by API servers that conform to the Corev specification.
Thex-corev-action
header helps distinguish between operation intents.
Thex-corev-env
header enables environment-scoped configurations.
If
x-corev-env
is not set, the server SHOULD assume the"production"
environment by default.
All configuration files SHOULD follow the naming convention below:
<project>@<version>.json
Example:
configs/atlas@1.0.0.json
Every configuration file SHOULD conform to the JSON schema below, which precisely defines the required structure and fields:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"version": {
"type": "string"
},
"config": {
"type": "object",
"additionalProperties": true
}
},
"required": [
"name",
"version",
"config"
],
"additionalProperties": false
}
Sections 1, 2, 3, 4 and 5 below describe a recommended API contract for compatibility with Corev-CLI. The specification is divided into two main parts: the methods (belonging to the
ConfigService
interface) and the dictionaries (Configuration
andUploadResponse
).
Belongs to the Corev ConfigService conformance class.
Expects a single argument, projectName
, which identifies the project. It returns a promise that
resolves with a Configuration
object containing the latest configuration for that project.
partial interface ConfigService {
Promise<Configuration> getLatestConfig(DOMString projectName);
};
Behavior:
- When this method is invoked, the implementation MUST retrieve the latest configuration from
storage (or memory) and return it as a
Configuration
object. - If the project is not found, the promise SHOULD be rejected with an appropriate error.
Belongs to the Corev ConfigService conformance class. Expects two arguments:
projectName
, a DOMString specifying the projectversion
, a DOMString specifying the version to retrieve
partial interface ConfigService {
Promise<Configuration> getSpecificConfig(DOMString projectName, DOMString version);
};
Behavior:
- When this method is invoked, the implementation MUST retrieve the configuration for the specified
project and version from storage (or memory) and return it as a
Configuration
object. - If the project or the specific version is not found, the promise SHOULD be rejected with an appropriate error (e.g., HTTP 404).
Belongs to the Corev ConfigService conformance class.
Expects two arguments:
projectName
, a DOMString specifying the project.config
, aConfiguration
object to be stored or updated.
partial interface ConfigService {
Promise<UploadResponse> uploadConfig(DOMString projectName, Configuration config);
};
Behavior:
- When this method is invoked, the implementation MUST store or update the configuration for the
specified project, then return an
UploadResponse
indicating success or error. - If policy doesn’t allow a duplicate or earlier version of a configuration, this method SHOULD
reject with a
409 Conflict
-like error or return an appropriate error response in theUploadResponse
.
Represents the structure of a project configuration object.
dictionary Configuration {
required DOMString name; // Project name (e.g., "atlas")
required DOMString version; // Version string (e.g., "1.0.0")
required any config; // JSON object with configuration data
};
Usage notes:
name
typically matches the project identifier (for example, "atlas").version
can be any string representing a version (for example, "1.0.0," "2025.04.13-alpha,").config
is an arbitrary JSON-like structure containing key-value pairs relevant to the configuration.
Defines the response returned after a successful (or failed) configuration upload.
dictionary UploadResponse {
required DOMString status; // "success" or "error"
DOMString? message; // Optional message with details
};
Usage notes:
status
MUST be either"success"
or"error"
.message
MAY be provided to give further context, such as error details or confirmations.
Start the mock API:
node tests/mock-api.mjs
Then run CLI commands while targeting http://localhost:3000
.
See CONTRIBUTING.md for contribution guidelines.
Corev-CLI is released under the MIT License.