Skip to main content

Stack distribution that pins compatible JARVIS components.

Project description

JARVIS Release (Stack Distribution)

JARVIS_Release is the version-pinned, runnable stack distribution for JARVIS (ARP spec/v1). It ships a lock file + Docker Compose setup that brings up a full local stack with sensible defaults.

What this repo ships

Core spec-facing services:

  • Run Gateway
  • Run Coordinator
  • Atomic Executor
  • Composite Executor
  • Node Registry
  • Selection Service
  • PDP

Internal JARVIS services:

  • Run Store
  • Event Stream
  • Artifact Store

Local dev STS (default profile):

  • Keycloak (dev-secure-keycloak)

Version pinning

  • stack.lock.json is the stack source of truth (component versions, node pack versions, helper libs).
  • pyproject.toml pins the same component versions for the arp-jarvis meta package.

Decision: Mode B / per-service GHCR images. Each JARVIS component repo publishes a GHCR image on vX.Y.Z tags. This repo consumes those images via Docker Compose and pins the references in stack.lock.json.

Quickstart (CLI-first, dev-secure-keycloak)

  1. Copy the env template:

Default (dev-secure-keycloak):

cp compose/.env.example compose/.env.local

Dev-insecure (no inbound JWT):

cp compose/.env.example.insecure compose/.env.local

Optional (dev-insecure, macOS/Linux or WSL) one-command bring-up:

bash ./start_dev.sh \
  --llm-api-key "<your_openai_api_key>" \
  --llm-chat-model "gpt-4.1-mini"
  1. Configure the LLM (required for Selection Service + Composite Executor):
  • Set ARP_LLM_API_KEY and ARP_LLM_CHAT_MODEL in compose/.env.local.
  • OpenAI is the default profile; ARP_LLM_PROFILE=openai is optional.
  • For offline tests, you can opt into ARP_LLM_PROFILE=dev-mock (not the default).
  1. Install the meta CLI:
python3 -m pip install -e .
arp-jarvis versions

This installs the arp-jarvis CLI version from your local checkout, while the Docker images remain pinned separately via STACK_VERSION in compose/.env.local and stack.lock.json.

  1. Bring up the stack and verify wiring:
arp-jarvis stack pull
arp-jarvis stack up -d
arp-jarvis doctor
  1. If using dev-secure-keycloak (default), log in once:
arp-jarvis auth login

This is a browser/device flow. The CLI never asks for your password directly. For the default local realm, a dev user is pre-seeded; the credentials are only for the Keycloak login page during the browser step.

  1. Start a run:
arp-jarvis runs start --goal "Generate a UUID, then return it."

Notes:

  • Keycloak is exposed on http://localhost:8080 (issuer default).
  • Run Gateway is exposed on 8081. Run Coordinator is exposed on 8082 (configure via RUN_COORDINATOR_HOST_PORT).
  • If you change KEYCLOAK_HOST_PORT, update ARP_AUTH_ISSUER in compose/profiles/dev-secure-keycloak.env.
  • dev-insecure disables inbound JWT checks but still runs Keycloak for service-to-service token exchange.
  • Node Registry runs with ARP_AUTH_MODE=optional to allow Selection Service calls (current Selection client does not attach bearer tokens).

Docker Compose fallback (no CLI)

docker compose --env-file compose/.env.local -f compose/docker-compose.yml up -d
curl -s http://localhost:8081/v1/health

Stack profiles

Set STACK_PROFILE in compose/.env.local to one of:

  • dev-secure-keycloak (default)
  • dev-insecure
  • enterprise (template only)

Meta CLI (arp-jarvis)

Convenience commands for interacting with the running stack:

arp-jarvis doctor
arp-jarvis auth login
arp-jarvis nodes list
arp-jarvis runs start --goal "Generate a UUID, then return it."

Compose wrapper (does not replace docker compose):

arp-jarvis stack up -d --print-command

You can also invoke component CLIs via arp-jarvis:

arp-jarvis run-gateway --help
arp-jarvis run-coordinator --help
arp-jarvis atomic-executor --help

Repo layout

JARVIS_Release/
  stack.lock.json
  compose/
    docker-compose.yml
    .env.example
    profiles/
      dev-secure-keycloak.env
      dev-insecure.env
      enterprise.env
    keycloak/
      realm-arp-dev.json
  assets/ (diagrams, logos)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

arp_jarvis-0.3.6.tar.gz (22.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

arp_jarvis-0.3.6-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file arp_jarvis-0.3.6.tar.gz.

File metadata

  • Download URL: arp_jarvis-0.3.6.tar.gz
  • Upload date:
  • Size: 22.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for arp_jarvis-0.3.6.tar.gz
Algorithm Hash digest
SHA256 8cf81a72c2ab4ea0b3e9b561a2f6fb11626bbb46366f41cdaf0ce7b9f0555fbc
MD5 01c2107594334d48b7b6528efeca3c2d
BLAKE2b-256 88da93c30139e331a9dd3015ba39e3e4c1e2fbd3869bdd25a0e3706710c4f524

See more details on using hashes here.

Provenance

The following attestation bundles were made for arp_jarvis-0.3.6.tar.gz:

Publisher: publish.yml on AgentRuntimeProtocol/JARVIS_Release

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file arp_jarvis-0.3.6-py3-none-any.whl.

File metadata

  • Download URL: arp_jarvis-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 21.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for arp_jarvis-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 609cf07c7a993d7484abd66c58549d5caa8ecfd8c6b6e5d9de75e3623fbc6436
MD5 d90a3db42370a5b9c0ae95a0bcaadca3
BLAKE2b-256 12ea78b910955712100acabd2b3a4343318a161248d6f312091a0a75592ffbdc

See more details on using hashes here.

Provenance

The following attestation bundles were made for arp_jarvis-0.3.6-py3-none-any.whl:

Publisher: publish.yml on AgentRuntimeProtocol/JARVIS_Release

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page