Skip to content

e-Próspera CLI

The official CLI wraps the public API in commands that are easier for humans, scripts, CI jobs, and AI agents to call safely. Use it when your runtime can execute shell commands. Use direct HTTP only when you are building your own client, need an endpoint the CLI does not cover, or cannot install Node tooling.

Source repository: Honduras-Prospera-inc/eprospera-cli.

Install

bash
npm install -g @prospera/eprospera-cli
eprospera --help

The CLI requires a modern Node.js runtime. See the GitHub repository for the current supported Node versions and release notes.

Authenticate

The CLI resolves credentials in this order:

  1. --api-key <value>
  2. EPROSPERA_API_KEY
  3. Credentials saved by eprospera auth login

For one-off automation, pass the key explicitly or through the environment:

bash
export EPROSPERA_API_KEY="ak-..."
eprospera --json entity verify 80000000000012

To store an Agent Key for later commands, cache the scopes you granted in the portal:

bash
eprospera --api-key "$EPROSPERA_API_KEY" auth login \
  --agent-key \
  --scopes agent:verify_rpn,agent:registry.search,agent:entity.read

Use --standard-key instead of --agent-key for a standard sk-... key. Agent Keys remain scope-checked by the API; cached scopes are a local preflight and do not grant permissions by themselves.

Agent Mode

For automation, prefer this shape:

bash
eprospera --json --yes <group> <command>
  • --json prints machine-readable JSON and suppresses spinners and color.
  • --raw prints compact single-line JSON when token efficiency matters.
  • --fields id,statusId,name trims read output to selected top-level fields.
  • --yes skips confirmation prompts for write commands.
  • --dry-run validates locally and prints the request that would be sent.
  • EPROSPERA_ENV=staging points the CLI at staging.
  • EPROSPERA_BASE_URL=<url> overrides the API base URL for trusted endpoints.

Parse stdout as data. Treat stderr as diagnostics.

Command Matrix

GoalCLI commandCredentialsScope
Verify an RPNeprospera --json entity verify <rpn>ak-, sk-agent:verify_rpn
Search legal entitieseprospera --json entity search "<query>"ak-, sk-agent:registry.search
Fetch one legal entityeprospera --json entity get <id>ak-, sk-agent:entity.read
Fetch entity documentseprospera --json entity documents <id>ak-, sk-agent:entity.documents.read
List API-created applicationseprospera --json application listak-, sk-agent:entity.application.read
Create an applicationeprospera --json --yes application create --file application.jsonak-, sk-agent:entity.application.create
Fetch one applicationeprospera --json application get <id>ak-, sk-agent:entity.application.read
Pay with couponeprospera --json --yes application pay <id> --coupon <code>ak-, sk-agent:entity.application.pay
Watch until terminal stateeprospera --json application watch <id> --timeout 30mak-, sk-agent:entity.application.read
Read owner profileeprospera --json me profileak-, OAuthagent:person.details.read
Read owner residencyeprospera --json me residencyak-, OAuthagent:person.residency.read
Read ID verificationeprospera --json me id-verificationak-, OAuthagent:person.id_verification.read

The CLI also includes auth, config, completion, and schema commands:

bash
eprospera --json auth whoami
eprospera --json config list
eprospera completion zsh
eprospera schema

Common Workflows

Verify and fetch an entity

bash
eprospera --json entity verify 80000000000012
eprospera --json entity search 80000000000012
eprospera --json entity get <id>

entity verify confirms whether the RPN is known and active. It does not return the legal-entity UUID, so use entity search before entity get.

Create, pay, and watch an LLC application

bash
eprospera --json --dry-run application create --file application.json
eprospera --json --yes application create --file application.json
eprospera --json --yes application pay <application-id> --coupon FOUNDER100
eprospera --json application watch <application-id> --timeout 30m

Write-capable Agent Keys require an active Manifestation of Will. Fully headless incorporation also requires the owner to pre-accept the Agreement of Coexistence for the target residency type. See Agent recipes for a complete request file and failure handling.

Read the key owner

bash
eprospera --json --fields id,fullName,email me profile
eprospera --json me residency
eprospera --json me id-verification

These commands accept Agent Keys or OAuth credentials. Standard sk-... keys are not valid for me commands.

Exit Codes

CodeMeaningAgent behavior
0SuccessContinue.
1Unexpected failureSurface the error and stop.
2Invalid usageFix command syntax or inspect eprospera schema.
3Authentication failureAsk for a credential or run auth login.
4Authorization failureAsk for a key with the missing scope.
5Resource not foundStop retrying the same lookup.
6ConflictAsk for different input or state.
7Rate limitRespect Retry-After and retry later.
8Validation errorFix local input using error.details.
9TimeoutSurface the last polling state.
10Terminal application/payment failureStop and ask for new input.

Machine-mode errors use this shape:

json
{
  "error": {
    "code": "INVALID_USAGE",
    "message": "Human-readable failure.",
    "details": {}
  }
}

When to Use Direct HTTP

Use the REST reference pages and curl examples when:

  • You are building an SDK, service integration, or browser/backend client.
  • You need OAuth authorization-code flows.
  • You need an endpoint the CLI does not cover.
  • You want exact wire-level request and response shapes.

For direct HTTP rules, see Conventions, Agent Keys, and the endpoint reference pages.