Multi-provider model routing, prompt templates, session state, and metrics for the Dabbler AI-led-workflow.
Project description
Dabbler AI Orchestration
An AI-led coding-session workflow for VS Code. Structured AI sessions with cross-provider verification, automatic cost tracking, git- worktree-aware session-set state, and a Session Set Explorer in the activity bar.
What this repo is for
The framework treats AI coding work as a sequence of sessions —
bounded slices that run to completion in one orchestrator
conversation, end with a verification + commit, and stop. A
session set is an ordered chain of sessions that delivers one
feature, refactor, or aspect of the solution. Each set lives at
docs/session-sets/<slug>/ with a small predictable shape (spec.md,
session-state.json, activity-log.json, change-log.md).
Inside each session, the orchestrator (Claude Code, Codex,
GitHub Copilot, or Gemini Code Assist) does mechanics — file edits,
shell, git — and dispatches every reasoning task (code review,
security review, analysis, architecture, documentation, test
generation, end-of-session verification) through ai_router.route().
The router picks the cheapest capable model per task type, escalates
on poor responses, and runs cross-provider verification by a
different provider to catch provider-specific blind spots.
Every routed call is appended to ai_router/router-metrics.jsonl, so
per-set, per-task, and per-model spend is fully auditable. The
Session Set Explorer extension is the at-a-glance companion: it reads
the same files the router writes and renders three groups in the
activity bar (In Progress, Not Started, Done), with
worktree auto-discovery so parallel sessions surface across sibling
workspaces. Full execution mechanics live at
docs/ai-led-session-workflow.md;
deeper feature descriptions live at
docs/repository-reference.md.
Highlights
- Session sets and sessions — Work is organized into bounded sessions inside ordered session sets, each with its own folder of artifacts the extension reads to render the activity-bar inventory. Deep dive.
- Cost-minded orchestration — The router routes each task to the cheapest capable tier, escalates on poor responses, and uses a per-task-type effort overrides. Real metrics from contrasting projects show 73% savings vs Opus-only on a CLI/library project (990 calls) and 32% savings on a full-stack UI app with UAT/E2E gates (370 calls) — see docs/sample-reports/ for the full reports. Deep dive.
- Cross-provider verification — Every session ends with a
mandatory independent verification by a model from a different
provider. The verifier returns structured JSON
(
{"verdict": "VERIFIED" | "ISSUES_FOUND", "issues": [...]}); the orchestrator surfaces disagreements for human adjudication rather than self-resolving. Deep dive. - Git integration + parallel session sets — Every session ends
with
git add -A && git commit && git push. Multiple session sets can run in parallel via isolated git worktrees onsession-set/<slug>branches, with the last session merging back into main cleanly. Deep dive. - Robust fallbacks — Tier escalation on empty/truncated/refused responses; two-attempt verifier fallback when a provider's HTTPS layer fails; documented escalation ladder if both verifier attempts fail. The work is preserved in git for human review either way. Deep dive.
- UAT + E2E support (opt-in) — Repos that flag
requiresUAT: trueand/orrequiresE2E: trueget a UAT checklist with E2E pre- screening; functional checklist items must have matching Playwright coverage before the human is asked to review. No-UI repos default to the universal core (build, test, verify, commit) with no UAT/E2E surface area. Deep dive.
Quick start
- Install the extension from the VS Code Marketplace:
- VS Code → Extensions view (
Ctrl+Shift+X) → searchDabbler AI Orchestration→ Install. - Or from a terminal:
code --install-extension DarndestDabbler.dabbler-ai-orchestration. - Or directly from the Marketplace listing.
- Offline / firewall fallback: the most recent VSIX is committed at
tools/dabbler-ai-orchestration/dabbler-ai-orchestration-0.13.3.vsix; Extensions → ... → Install from VSIX... picks it up.
- VS Code → Extensions view (
- Open your workspace. Any folder with — or destined for — a
docs/session-sets/directory. The activity-bar Session Set Explorer icon appears automatically once that path is present. - Run
Dabbler: Install ai-routerfrom the command palette (Ctrl+Shift+P). The command auto-detects (or offers to create) a workspace.venv/, runspip install dabbler-ai-routerinside it, and materializesai_router/router-config.yamlfor tuning.
Then set API keys as environment variables (one-time):
ANTHROPIC_API_KEY, GEMINI_API_KEY, OPENAI_API_KEY — the
Prerequisites section below has
the sign-up links and notes which providers are required.
Subsequent updates: Dabbler: Update ai-router from the command
palette.
CLI fallback —
python -m venv .venv && .venv/Scripts/pip install dabbler-ai-router, thenfrom ai_router import routefrom your orchestrator script.
For new projects: adoption bootstrap
If you're starting a new project — greenfield, an existing local
project that hasn't yet adopted the workflow, or a remote repo you
want to clone in — the recommended starting point is
Dabbler: Copy adoption bootstrap prompt from the command palette.
The command copies a short engine-agnostic prompt to your clipboard
that you paste into a fresh AI chat (Claude Code, Gemini Code Assist,
or any GPT-based tool). The AI then fetches the canonical online
instructions at
docs/adoption-bootstrap.md and runs an
interactive flow: detect your workspace state, run a budget-threshold
dialog, propose a session-set decomposition, present a numbered
checklist of every intended write / config / scaffolding action for
batch approval before executing. No per-write prompts; you can
interrupt at any time. The four-tier budget mapping is documented in
docs/ai-led-session-workflow.md → Cost-budgeted verification modes.
This entry point sits before the
Quick start above for greenfield work — the bootstrap
flow installs the router, scaffolds the folders, authors
docs/planning/project-plan.md and your first session-set specs, and
saves your budget threshold to ai_router/budget.yaml as part of its
action checklist.
Prerequisites: tools and accounts
You need VS Code, at least one orchestrator agent installed as a VS Code extension, and API-key accounts for all three model providers (the router calls all three so cross-provider verification has somewhere to route to).
VS Code
- Download: code.visualstudio.com
- Getting-started docs:
code.visualstudio.com/docs —
the Extensions view (
Ctrl+Shift+X) is what you'll use to install the Session Set Explorer in the Quick start above.
Orchestrator agents (install at least one)
Pick whichever AI agent you want to drive sessions; the framework is provider-agnostic and you can switch mid-set.
- Claude Code (Anthropic) — reads CLAUDE.md. Install via claude.com/product/claude-code; docs at docs.claude.com/en/docs/claude-code/overview.
- Codex (OpenAI) — reads AGENTS.md. See openai.com/codex and the open-source CLI repo at github.com/openai/codex.
- GitHub Copilot — reads AGENTS.md. See github.com/features/copilot; Marketplace listing at GitHub.copilot.
- Gemini Code Assist (Google) — reads GEMINI.md. See codeassist.google (free tier available); docs at cloud.google.com/gemini/docs/codeassist/overview.
API keys (all three required)
The router calls all three providers and cross-provider verification needs at least two providers live to be meaningful. Expect to set up all three.
ANTHROPIC_API_KEY— console.anthropic.com (Settings → API Keys, requires billing).GEMINI_API_KEY— aistudio.google.com (Get API key in the left rail; free tier is generous).OPENAI_API_KEY— platform.openai.com (create a project, add a payment method, mint a key).
Set each as a Windows User environment variable; macOS / Linux export
them in your shell profile. Optionally,
pushover.net's PUSHOVER_API_KEY and
PUSHOVER_USER_KEY enable end-of-session phone notifications — if
unset, the orchestrator skips the notify and prints to console as
usual.
More
For technical reference (deep feature descriptions, the UAT/E2E flag matrix, a worked end-of-session output example, and the repository file map), see docs/repository-reference.md.
For runtime mechanics (trigger phrases, the 10-step procedure, the authoritative rule list every orchestrator obeys), see docs/ai-led-session-workflow.md.
For sample manager-report output from real projects at scale, see docs/sample-reports/.
For worked examples of cross-provider AI consultation in practice — what each provider explored, where they agreed and meaningfully differed, and what makes the pattern worth using — see docs/case-studies/.
License
This repo is released under the MIT License. See LICENSE for the full text. Copyright © 2026 darndestdabbler.
A duplicate
LICENSElives at tools/dabbler-ai-orchestration/LICENSE alongside the extension'spackage.json. The duplication is required:vsce packageexpects the file beside the manifest and has no flag to point elsewhere. Both files must be kept in sync.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dabbler_ai_router-0.5.1.tar.gz.
File metadata
- Download URL: dabbler_ai_router-0.5.1.tar.gz
- Upload date:
- Size: 227.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8ce48c8b518d4cba46a5c38cf97b02a3d728e66e60344143d1feb996aef626ab
|
|
| MD5 |
21bf626f2ce90822998ef92182962f09
|
|
| BLAKE2b-256 |
22757fe368c920ab430d3c41da6d379a56c7872fe42536716135f5b96c0459af
|
Provenance
The following attestation bundles were made for dabbler_ai_router-0.5.1.tar.gz:
Publisher:
release.yml on darndestdabbler/dabbler-ai-orchestration
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
dabbler_ai_router-0.5.1.tar.gz -
Subject digest:
8ce48c8b518d4cba46a5c38cf97b02a3d728e66e60344143d1feb996aef626ab - Sigstore transparency entry: 1575503078
- Sigstore integration time:
-
Permalink:
darndestdabbler/dabbler-ai-orchestration@b30b55252f5a53fd91a730141e3268951cc801eb -
Branch / Tag:
refs/tags/v0.5.1 - Owner: https://github.com/darndestdabbler
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@b30b55252f5a53fd91a730141e3268951cc801eb -
Trigger Event:
push
-
Statement type:
File details
Details for the file dabbler_ai_router-0.5.1-py3-none-any.whl.
File metadata
- Download URL: dabbler_ai_router-0.5.1-py3-none-any.whl
- Upload date:
- Size: 246.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b78d8e06685f915122b93107855fb74e8555316e016d4fdcf3bf6215f344d8b6
|
|
| MD5 |
b4089cad0d42489502233f586f10b96d
|
|
| BLAKE2b-256 |
9becf592d55f739f330e94cf1bf961741fa066f5c872207a0a95907b0466fdc6
|
Provenance
The following attestation bundles were made for dabbler_ai_router-0.5.1-py3-none-any.whl:
Publisher:
release.yml on darndestdabbler/dabbler-ai-orchestration
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
dabbler_ai_router-0.5.1-py3-none-any.whl -
Subject digest:
b78d8e06685f915122b93107855fb74e8555316e016d4fdcf3bf6215f344d8b6 - Sigstore transparency entry: 1575503096
- Sigstore integration time:
-
Permalink:
darndestdabbler/dabbler-ai-orchestration@b30b55252f5a53fd91a730141e3268951cc801eb -
Branch / Tag:
refs/tags/v0.5.1 - Owner: https://github.com/darndestdabbler
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@b30b55252f5a53fd91a730141e3268951cc801eb -
Trigger Event:
push
-
Statement type: