Skip to main content

JARVIS Selection Service implementation for the ARP Standard (spec/v1).

Project description

JARVIS Selection Service

First-party OSS reference implementation of the ARP Selection Service.

The Selection Service produces bounded candidate sets for mapping subtasks to NodeTypes. The selection strategy is intentionally implementation-defined; JARVIS uses LLM-assisted ranking by default (via arp-llm) and returns an error if selection cannot be produced.

Implements: ARP Standard spec/v1 Selection API (contract: ARP_Standard/spec/v1/openapi/selection.openapi.yaml).

Requirements

  • Python >= 3.10

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

  • Selection Service listens on http://127.0.0.1:8085 by default.
python3 -m pip install -e .
python3 -m jarvis_selection_service

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

Using this repo

To build your own selection service, fork this repository and replace the selection strategy while preserving request/response semantics.

If all you need is to change selection strategy, edit:

  • src/jarvis_selection_service/strategy.py

Outgoing client wrapper (selection -> node registry):

  • src/jarvis_selection_service/node_registry_client.py

Default behavior

  • Builds inventory from Node Registry (atomic-first).
  • Uses arp-llm to rank atomic candidates for a subtask.
  • Adds the composite planner node type when the LLM indicates the task does not fit a single atomic node.
  • Planner NodeTypes are seeded by Node Registry (e.g. jarvis.composite.planner.general).
  • Applies constraints.candidates.allowed_node_type_ids / denied_node_type_ids if provided.
  • Applies constraints.candidates.max_candidates_per_subtask as the top-K bound when provided.
  • Returns an error if the LLM is unavailable or no candidates can be produced.

Extensions

The Selection API surfaces extensions in both inputs and outputs. This implementation uses them as follows:

Consumes NodeType.extensions from Node Registry inventory:

  • jarvis.role (planner detection)
  • jarvis.side_effect, jarvis.egress_policy, jarvis.tags (enrich the LLM menu)

Writes CandidateSet.extensions for observability:

  • jarvis.selection.strategy (currently llm)
  • jarvis.llm.provider, jarvis.llm.model, jarvis.llm.latency_ms

Passthrough:

  • Any keys provided in CandidateSetRequest.extensions are copied into CandidateSet.extensions (non-sensitive metadata only).

Reserved (accepted but not required in v0.3.x):

  • SubtaskSpec.extensions.jarvis.subtask.notes
  • SubtaskSpec.extensions.jarvis.root_goal

Full cross-stack list: https://github.com/AgentRuntimeProtocol/BusinessDocs/blob/main/Business_Docs/JARVIS/Extensions.md.

Quick health check

curl http://127.0.0.1:8085/v1/health

Configuration

CLI flags:

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

Env vars (selected):

  • JARVIS_NODE_REGISTRY_URL (required)
  • JARVIS_NODE_REGISTRY_AUDIENCE (optional; outbound token exchange audience)
  • JARVIS_SELECTION_STRATEGY (default llm; other strategies are not supported yet)
  • JARVIS_SELECTION_TOP_K_DEFAULT (optional)
  • JARVIS_SELECTION_PLANNER_NODE_TYPE_ID (optional; planner fallback is auto-detected)

LLM (required when JARVIS_SELECTION_STRATEGY=llm):

  • ARP_LLM_PROFILE, ARP_LLM_CHAT_MODEL, ARP_LLM_API_KEY, ...
    • See https://github.com/AgentRuntimeProtocol/BusinessDocs/blob/main/Business_Docs/JARVIS/LLMProvider/HLD.md and https://github.com/AgentRuntimeProtocol/BusinessDocs/blob/main/Business_Docs/JARVIS/LLMProvider/LLD.md.

Validate conformance (arp-conformance)

python3 -m pip install arp-conformance
arp-conformance check selection --url http://127.0.0.1:8085 --tier smoke
arp-conformance check selection --url http://127.0.0.1:8085 --tier surface

Helper scripts

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

  • src/scripts/send_request.py: generate a candidate set from a JSON file.

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

Authentication

Auth is enabled by default (JWT). To disable for local dev, set ARP_AUTH_PROFILE=dev-insecure.

To enable local Keycloak defaults, set:

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

Outbound service-to-service calls (Node Registry / PDP) should use STS token exchange (no static bearer tokens). Configure the STS client credentials with:

  • ARP_AUTH_CLIENT_ID
  • ARP_AUTH_CLIENT_SECRET
  • ARP_AUTH_TOKEN_ENDPOINT

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_selection_service-0.3.3.tar.gz (11.6 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_selection_service-0.3.3-py3-none-any.whl (13.9 kB view details)

Uploaded Python 3

File details

Details for the file arp_jarvis_selection_service-0.3.3.tar.gz.

File metadata

File hashes

Hashes for arp_jarvis_selection_service-0.3.3.tar.gz
Algorithm Hash digest
SHA256 6333ff79001565ee663fd1f48785f479da9991d8b39790438e83cfc02c608a8e
MD5 f072c8cc27a0d818d9b563ddc5edba1d
BLAKE2b-256 a1ced0ad54bcc69d96dca0f8513e582c192155a18568f1bc88a686cf7a7cec29

See more details on using hashes here.

Provenance

The following attestation bundles were made for arp_jarvis_selection_service-0.3.3.tar.gz:

Publisher: release.yml on AgentRuntimeProtocol/JARVIS_SelectionService

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_selection_service-0.3.3-py3-none-any.whl.

File metadata

File hashes

Hashes for arp_jarvis_selection_service-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6b8d766f385d3bda72147af1ff17b0c2e96c585f635353554e37ab21d8a7e801
MD5 7aef9281c4ffb34151e1731f8609c289
BLAKE2b-256 179ee0632647e0b9500fc876ecde9cf286f9e25844c12c071f83ca6d4ee51e22

See more details on using hashes here.

Provenance

The following attestation bundles were made for arp_jarvis_selection_service-0.3.3-py3-none-any.whl:

Publisher: release.yml on AgentRuntimeProtocol/JARVIS_SelectionService

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