Skip to main content

Deterministic AI Gateway

Project description

AI Gateway

Tests Python License PyPI version

This repository provides a deterministic execution boundary for LLM calls.

It enforces an explicit separation between request, decision, and execution, and records every interaction as an append-only, replayable event stream.

This is not:

  • an agent framework
  • a RAG pipeline
  • a workflow engine
  • a UI product

The gateway does not decide what to do. It decides whether an explicitly declared action may execute.


Repository Landscape

The gateway is part of a small toolchain:

deterministic-ai-gateway (this repository)

Authoritative execution boundary and event log. The gateway is authoritative for execution, but not for interpretation. It emits facts, not narratives.

  • Accepts explicit intents.
  • Applies policy.
  • Executes provider calls.
  • Emits canonical events (INTENT, DECISION, EXECUTION).
  • Persists an append-only event trail.
  • Exposes read-only observation surfaces (/snapshot, /tail).

dbl-operator

Observer and intervention client. Used for rendering timelines, audits, and decision views. Does not evaluate policy or store authoritative state.

dbl-chat-cli

Minimal interactive CLI client for smoke testing and quick interaction via terminal.

dbl-chat-client

Pure event-projection UI. Real-time visualization of the gateway event stream and identity anchor management.


Interaction Model

Every interaction follows the same sequence:

  1. INTENT – explicit request with identity anchors (thread_id, turn_id).
  2. DECISION – policy outcome (ALLOW/DENY).
  3. EXECUTION – provider call and result.
  4. OBSERVATION – read-only access via snapshot or tail.

Only DECISION events are normative. EXECUTION events are observational and cannot influence policy or state.

No step is implicit; every event is linked via a stable correlation_id.


Design Principles

  • Explicit boundaries: Strict separation between core logic, policy, and execution.
  • Append-only records: Immutable event trail for audit and replay.
  • No hidden state: No heuristics or internal memory beyond the event stream.
  • Observer-safe: Clients may observe and project state, but cannot affect policy, execution, or event ordering.

Context System (v0.4.0+)

The gateway supports explicit context declaration for multi-turn conversations.

declared_refs

Clients can reference prior events as context via IntentEnvelope.payload.declared_refs:

{
  "declared_refs": [
    {"ref_type": "event", "ref_id": "correlation-id-1"},
    {"ref_type": "event", "ref_id": "turn-id-2"}
  ]
}

I_context / O_context Split

Type Admitted For Digest Scope Policy Access
INTENT events governance ✅ Included ✅ Yes
EXECUTION events execution_only ✅ Included (audit) ❌ No

This ensures observations never influence governance decisions (DBL Claim 4).

Configuration

Context behavior is controlled by config/context.json:

{
  "max_refs": 50,
  "empty_refs_policy": "DENY",
  "canonical_sort": "event_index_asc",
  "enforce_scope_bound": true
}

The config digest is pinned in every DECISION event for replay verification.

See docs/CONTEXT.md for the full specification.


Installation

Local Install

Create a virtual environment and install the gateway:

pip install .

Docker

The gateway can be started with a single Docker command. No interactive setup, no hidden defaults.

docker build -t dbl-gateway .
docker run -p 8010:8010 \
  -e OPENAI_API_KEY="sk-..." \
  -e DBL_GATEWAY_POLICY_MODULE="dbl_policy.allow_all" \
  dbl-gateway

Running the Gateway

Required Environment Variables

Variable Description
OPENAI_API_KEY Provider API key.
DBL_GATEWAY_POLICY_MODULE Policy module (e.g., dbl_policy.allow_all).
DBL_GATEWAY_POLICY_OBJECT Policy object inside the module (default: policy).

Start Command

dbl-gateway serve --host 127.0.0.1 --port 8010

Observation Surfaces

Snapshot (/snapshot)

Returns a point-in-time state of the event log. Suitable for audits and offline inspection.

Tail (/tail)

A live SSE stream of events.

  • since: Start streaming from a specific event index.
  • backlog: Number of recent events to emit on connect (default: 20).

Integration Examples

Using the Operator

$env:DBL_GATEWAY_BASE_URL = "http://127.0.0.1:8010"
dbl-operator thread-view --thread-id t-1

Using the Chat CLI

dbl-chat-cli --base-url http://127.0.0.1:8010 --principal-id user-1

Using the Chat Client

# In the dbl-chat-client repository:
npm install && npm run dev

Status

Early, but operational. Core execution, policy gating, and auditing are stable. Current focus: surface stabilization and contract clarity.

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

deterministic_ai_gateway-0.4.0.tar.gz (56.0 kB view details)

Uploaded Source

Built Distribution

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

deterministic_ai_gateway-0.4.0-py3-none-any.whl (50.7 kB view details)

Uploaded Python 3

File details

Details for the file deterministic_ai_gateway-0.4.0.tar.gz.

File metadata

  • Download URL: deterministic_ai_gateway-0.4.0.tar.gz
  • Upload date:
  • Size: 56.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.8

File hashes

Hashes for deterministic_ai_gateway-0.4.0.tar.gz
Algorithm Hash digest
SHA256 eb0ff135bf71a30138e07f106b94acffc7d20f0924e15f82fa19043f57177f23
MD5 12cddb3d15b47c95d8d6ade645632257
BLAKE2b-256 5e02a3caa1370a66a7d81f876c9493adf2773bc49e786fe0246b521565f8a593

See more details on using hashes here.

File details

Details for the file deterministic_ai_gateway-0.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for deterministic_ai_gateway-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 01e87c47bb0990c9cd067032c4b927815142e5c9c5dfa18f13a95d82d1a12c08
MD5 61a7e5b2b58ae4193d1c4ff6d73889eb
BLAKE2b-256 bbe9dca2cd4a6054e9b052c984bb1c94048c9912f343e2dd93184bf7f2648242

See more details on using hashes here.

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