Skip to main content

JARVIS Atomic Executor implementation for the ARP Standard (spec/v1).

Project description

JARVIS Atomic Executor

First-party OSS reference implementation of the ARP spec/v1 Atomic Executor.

This JARVIS component implements the Atomic Executor API using the SDK packages: arp-standard-server, arp-standard-model, and arp-standard-client.

Implements: ARP Standard spec/v1 Atomic Executor API (contract: ARP_Standard/spec/v1/openapi/atomic-executor.openapi.yaml).

Requirements

  • Python >= 3.11

Install

python3 -m pip install -e .

Local configuration (optional)

For local dev convenience, copy the example env file:

cp .env.example .env.local

src/scripts/dev_server.sh auto-loads .env.local (or .env).

Run

  • Atomic Executor listens on http://127.0.0.1:8082 by default.
python3 -m pip install -e .
jarvis-atomic-executor

[!TIP] Use bash src/scripts/dev_server.sh --host ... --port ... --reload for dev convenience.

Using this repo

This repo is the maintained JARVIS reference for atomic execution. Add or replace handlers while preserving ARP request/response semantics.

This executor auto-loads installed node packs via the jarvis.nodepacks entry point group (see arp-jarvis-atomic-nodes). If you want to override the default handler registry, pass handlers=... when constructing AtomicExecutor.

Default behavior

  • Loads handlers from installed node packs (entry points).
  • Includes jarvis.core.echo from the core pack.
  • execute_atomic_node_run returns succeeded with outputs={"echo": inputs} for the echo node.
  • Unknown node_type_id returns failed with an error payload.
  • cancel_atomic_node_run cancels in-flight handler execution (best-effort).

Common extensions

  • Add more node packs or override the handler registry explicitly.
  • Customize cancellation behavior (cooperative cancellation, idempotency, timeouts).
  • Configure timeouts/concurrency controls around handler execution.

Implementation overview

Request flow:

  1. Inbound request hits the Atomic Executor (arp-standard-server).
  2. Auth middleware validates the Authorization: Bearer <JWT> header (when enabled).
  3. The executor routes by node_type_ref.node_type_id and calls the matching handler.
  4. The executor returns AtomicExecuteResult with outputs and timing metadata.

System-of-record:

  • The Atomic Executor does not store run state or emit durable run events.
  • The Run Coordinator is responsible for orchestration, durability, and emitting atomic_executed.

Quick health check

curl http://127.0.0.1:8082/v1/health

Configuration

CLI flags:

  • --host (default 127.0.0.1)
  • --port (default 8082)
  • --reload (dev only)

Environment variables:

  • Incoming JWT validation is configured via ARP_AUTH_PROFILE and ARP_AUTH_* overrides (see .env.example).
  • Optional execution controls:
    • JARVIS_DEFAULT_TIMEOUT_SECS (coarse per-request timeout)
    • JARVIS_MAX_CONCURRENCY (cap concurrent executions)

Validate conformance (arp-conformance)

python3 -m pip install arp-conformance
arp-conformance check atomic-executor --url http://127.0.0.1:8082 --tier smoke
arp-conformance check atomic-executor --url http://127.0.0.1:8082 --tier surface

Helper scripts

  • src/scripts/dev_server.sh: run the server (flags: --host, --port, --reload).

  • src/scripts/send_request.py: execute an atomic NodeRun from a JSON file.

    python3 src/scripts/send_request.py --request src/scripts/request.json
    

    Note: this helper does not include an Authorization header. For a quick local run, set ARP_AUTH_PROFILE=dev-insecure (dev only), or call the Atomic Executor via the Run Coordinator (recommended).

Authentication

This service validates incoming JWTs (authn). It does not perform token exchange.

Auth is enabled by default (JWT). To disable for local dev, set ARP_AUTH_PROFILE=dev-insecure. If no ARP_AUTH_* env vars are set, the service defaults to required JWT auth with the dev Keycloak issuer.

To enable local Keycloak defaults, set:

  • ARP_AUTH_PROFILE=dev-secure-keycloak
  • ARP_AUTH_AUDIENCE=arp-atomic-executor
  • ARP_AUTH_ISSUER=http://localhost:8080/realms/arp-dev

Coordinator → Atomic Executor calls

In the JARVIS stack, the Run Coordinator is expected to:

  • mint/exchange a service-scoped JWT for the Atomic Executor audience via STS (OIDC/RFC 8693)
  • call POST /v1/atomic-node-runs:execute with Authorization: Bearer <token>

The Atomic Executor validates the JWT (signature + optional iss/aud) and executes the handler.

Upgrading

When upgrading to a new ARP Standard SDK release, bump pinned versions in pyproject.toml (arp-standard-*==...) and re-run conformance.

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_atomic_executor-0.3.5.tar.gz (8.9 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_atomic_executor-0.3.5-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file arp_jarvis_atomic_executor-0.3.5.tar.gz.

File metadata

File hashes

Hashes for arp_jarvis_atomic_executor-0.3.5.tar.gz
Algorithm Hash digest
SHA256 914734b686f9bf06d0245c405b806660487c676a595273df0451b538322d7bfd
MD5 f9a1670a8e8c1701ebc0cd7aa1bdcfe6
BLAKE2b-256 1423740c6fcd13c631796e95ee839c4df7d1f1b570ad15f273ed2910354c1283

See more details on using hashes here.

Provenance

The following attestation bundles were made for arp_jarvis_atomic_executor-0.3.5.tar.gz:

Publisher: publish.yml on AgentRuntimeProtocol/JARVIS_AtomicExecutor

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_atomic_executor-0.3.5-py3-none-any.whl.

File metadata

File hashes

Hashes for arp_jarvis_atomic_executor-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 fff86f6ab84f5192abea39ae5f390d7542faa726f15d8b75c6823c54d061da17
MD5 004232ed6be4c01da3317629e4c748a5
BLAKE2b-256 a8574e4b6d91fd7fd1010d5b2304fab0051ef2ead60daafee3a1db3cbe1ca450

See more details on using hashes here.

Provenance

The following attestation bundles were made for arp_jarvis_atomic_executor-0.3.5-py3-none-any.whl:

Publisher: publish.yml on AgentRuntimeProtocol/JARVIS_AtomicExecutor

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