Okto Pulse — spec-driven project management with AI agents via MCP. Local-first, single command setup.
Project description
Okto Pulse
Spec-driven project management for AI-assisted development.
Okto Pulse turns ideas, refinements, specs, tasks, tests and bugs into a governed SDLC board that AI agents can operate through MCP.
Ship with AI. Stay in control.
Table of Contents
- What is Okto Pulse?
- Platform Surface
- Get Started
- Connect an AI Coding Agent
- Core Workflow
- Governance Gates
- Knowledge Graph
- CLI Reference
- Run with Docker
- Data Storage
- From Source
- Troubleshooting
- Release Notes
- License
What is Okto Pulse?
Okto Pulse is a local-first SDLC workbench built for teams that use AI coding agents but still want traceability, quality gates and durable project memory.
Instead of sending an agent straight from a prompt to code, Okto Pulse keeps the work explicit:
Stories -> Ideation -> Refinement -> Spec -> Sprint -> Tasks / Tests / Bugs
Every stage has structured artifacts, lineage, status transitions and validation rules. Agents can create and update those artifacts through MCP tools, while humans can inspect and steer the same work in the web UI.
Platform Surface
Current 0.2.0 surface:
| Surface | Count |
|---|---|
| Governance gates | 15 |
| Core MCP tools | 216 |
| Community-only MCP tools | 0 |
MCP tools exposed by okto-pulse serve |
216 |
The community package mounts the full okto-pulse-core MCP server. That means installed community runtimes expose the complete core tool catalog while keeping the CLI, frontend and packaging layer separate from the core engine.
Get Started
1. Install
pip install okto-pulse
Okto Pulse requires Python 3.11+.
[!NOTE] On first run, Okto Pulse downloads the
all-MiniLM-L6-v2sentence-transformers model into the Hugging Face cache. This powers semantic search in the Knowledge Graph. If the model cannot be downloaded, the app still starts in deterministic stub mode and the Settings view reports that semantic search is disabled.
2. Initialize a workspace
Run this inside the project directory where your coding agent will work:
okto-pulse init
This creates:
- the local data directory under
~/.okto-pulse/ - a default board and agent
- a project-local
.mcp.jsonthat points your agent at the local MCP server
3. Start the app
okto-pulse serve
Default endpoints:
| Endpoint | URL |
|---|---|
| Web UI + API | http://localhost:8100 |
| MCP server | http://localhost:8101/mcp |
Both listeners run in one Python process. This keeps the embedded graph database under a single writer while still exposing independent API/UI and MCP ports.
4. Open the UI
Go to http://localhost:8100, select the default board and start with either:
- a Story, when you want lightweight pre-ideation context grouped by topic
- an Ideation, when the feature or problem is already ready to be discussed
Connect an AI Coding Agent
Most agent tools can discover the generated .mcp.json automatically when they run from the same directory.
| Agent or tool | Setup |
|---|---|
| Claude Code | Run it from the directory that contains .mcp.json. |
| Claude Desktop | Copy the generated MCP server block into Claude Desktop settings. |
| Cursor | Add the MCP server URL in Cursor MCP settings. |
| VS Code | Copy the server block into .vscode/mcp.json. |
| Windsurf / Cline | Use the generated .mcp.json when supported. |
Generated shape:
{
"mcpServers": {
"okto-pulse": {
"url": "http://localhost:8101/mcp?api_key=dash_..."
}
}
}
If you change the MCP port, regenerate the file:
okto-pulse init --agents
Core Workflow
Okto Pulse is intentionally workflow-first. Each stage answers a different question.
| Stage | Purpose |
|---|---|
| Stories | Optional lightweight user-story inputs, grouped by topic, that can feed one or more ideations. |
| Ideation | Capture the problem, assess ambiguity and collect Q&A before committing to a solution path. |
| Refinement | Investigate code, constraints, prior decisions, mockups, architecture and knowledge entries. |
| Spec | Define acceptance criteria, functional requirements, business rules, API contracts, tests and decisions. |
| Sprint | Slice approved specs into reviewable implementation batches when the work is large. |
| Tasks / Tests / Bugs | Execute implementation with linked tests, bug evidence, validation and conclusions. |
The lineage graph keeps these relationships inspectable, including story-to-ideation and task-to-test/bug relationships.
Governance Gates
Okto Pulse protects the workflow with checks that run on status transitions.
The platform currently has 15 named governance gates:
| Gate family | Gates |
|---|---|
| Resource readiness | Resource readiness; resource-to-task coverage |
| Spec coverage | Scenario/test coverage; functional requirement/business rule coverage; technical requirement/task coverage; API contract/task coverage; active decision/task coverage |
| Validation and evaluation | Spec validation; spec qualitative evaluation; task validation |
| Execution quality | Task start/spec readiness; task conclusion; test evidence; bug test-first/traceability |
| Sprint health | Sprint closure/evaluation |
- Specs require coverage across acceptance criteria, functional requirements, business rules, API contracts, decisions and test scenarios.
- Tasks cannot start until the parent spec has the required scenario coverage.
- Tasks moving to
donerequire a structured conclusion with completeness and drift assessment. - Test cards require evidence before they can be marked as automated, passed or failed.
- Bug cards follow a test-first workflow and must remain traceable to the task and related test work.
- Validation gates can require independent review before specs or tasks are considered complete.
Board settings let teams tune thresholds without removing the traceability model.
Knowledge Graph
Okto Pulse maintains an embedded per-board Knowledge Graph for durable project memory.
Agents use the graph to:
- find related prior decisions
- detect contradictions and superseded context
- reuse lessons from previous bugs
- query global discovery context across boards
- consolidate specs, bugs and implementation conclusions into searchable knowledge
Operational health is visible through:
- the in-product KG view
- MCP health tools
- dead-letter and queue metrics
- graph database runtime settings in the board settings panel
CLI Reference
| Command | Description |
|---|---|
okto-pulse init |
Initialize local data, seed the default board and generate .mcp.json. |
okto-pulse init --agents |
Regenerate MCP agent configuration. |
okto-pulse init --accept-terms |
Accept terms non-interactively. Also supported through OKTO_PULSE_TERMS_ACCEPTED=1. |
okto-pulse serve |
Start API/UI and MCP in one Python process. |
okto-pulse serve --api-port N --mcp-port M |
Override API/UI and MCP ports. |
okto-pulse status |
Show service status, database path, size and board counts. |
okto-pulse reset [-y] |
Delete local data and re-seed after confirmation. |
okto-pulse kg dedup-entities <board_id> |
Run the idempotent KG entity deduplication migration for a board. |
okto-pulse kg migrate-schema [--all-boards] |
Apply graph schema migrations manually. The runtime also auto-heals supported legacy schemas. |
Run with Docker
Published image
docker run -d --name okto-pulse \
-e HOST=0.0.0.0 \
-e MCP_HOST=0.0.0.0 \
-p 8100:8100 \
-p 8101:8101 \
-v okto-pulse-data:/data \
ghcr.io/oktolabsai/okto-pulse:latest
Then open http://localhost:8100 and retrieve the bootstrap API key:
docker exec okto-pulse okto-pulse api-key
Compose
Use the production compose file when you want a PyPI-based image:
docker compose -f docker-compose.prod.yml build
docker compose -f docker-compose.prod.yml up -d
Use the local compose file when hacking on the community package together with a sibling okto-pulse-core checkout:
docker compose build
docker compose up -d
Environment variables
| Variable | Default | Purpose |
|---|---|---|
HOST |
127.0.0.1 |
API/UI bind host. Use 0.0.0.0 in containers. |
MCP_HOST |
127.0.0.1 |
MCP bind host. Use 0.0.0.0 in containers. |
DATA_DIR |
~/.okto-pulse |
SQLite database, uploads and graph storage root. |
KG_BASE_DIR |
derived from DATA_DIR |
Per-board graph database location. |
HF_HOME |
~/.cache/huggingface |
Sentence-transformers model cache. |
MCP_TRACE_ENABLED |
unset | Set to 1 to record MCP calls for replay testing. |
MCP_TRACE_DIR |
${DATA_DIR}/mcp_traces |
Trace output directory when tracing is enabled. |
Data Storage
All default local state lives under ~/.okto-pulse/:
~/.okto-pulse/
|-- data/
| `-- pulse.db
|-- boards/
| `-- {board-id}/
| `-- graph.lbug
|-- global/
| `-- discovery.lbug
|-- uploads/
| `-- {board-id}/
`-- mcp_traces/
[!WARNING] Do not delete graph database directories to "fix" graph errors. Use the KG migration and health tools so schema or runtime issues remain diagnosable.
From Source
Clone both repositories next to each other:
git clone https://github.com/OktoLabsAI/okto-pulse-core.git
git clone https://github.com/OktoLabsAI/okto-pulse.git
cd okto-pulse
Install both packages in editable mode:
pip install -e ../okto-pulse-core -e .
okto-pulse init
okto-pulse serve
Build the frontend before packaging:
cd frontend
npm install
npm run build
cd ..
Troubleshooting
Embedding model did not download
Restore network access and restart:
okto-pulse serve
You can also smoke-test the embedder from a source checkout:
python scripts/smoke_embedding.py
AI agent cannot connect to MCP
Check that the MCP port in .mcp.json matches the running server:
okto-pulse serve --api-port 8100 --mcp-port 8101
okto-pulse init --agents
If running in Docker, expose the MCP listener with MCP_HOST=0.0.0.0 and publish the port.
Graph database reports lock, WAL or size errors
First confirm that only one okto-pulse serve process is using the same data directory. Then open board settings and check:
- Graph DB buffer pool size
- Graph DB max database size per board
- KG health and dead-letter metrics
Use the contextual error message as the source of truth when reporting an issue.
Release Notes
0.2.0
Branch changelog for feature/0.2.0:
- Adds Stories and Topics as optional pre-ideation intake, with topic filtering, lifecycle actions, Story modals, topic selection persistence across refreshes and Story-to-Ideation linking.
- Adds Resource Gate UI coverage for Architecture, Mockups and Knowledge Base readiness, including N/A/provided states, clear actions, validation feedback and modal refresh parity.
- Expands Ideation modals with Knowledge Base and Stories tabs, while preserving linked Refinements and lineage navigation.
- Improves lineage handling for Story, Ideation, Refinement, Spec, Sprint, Task, Test and Bug flows, including rootless Spec-started flows that do not have an Ideation ancestor.
- Fixes inline guideline creation paths that could surface 422 responses from
/boards/{board_id}/guidelines. - Hardens bug/test traceability in the UI and bundled API contracts, including Bug origin and regression coverage relationships produced by the deterministic KG worker.
- Adds an Evidence tab to Test card modals so users can audit linked scenario evidence, coverage gaps and
latest_evidencefallback data directly from the card. - Updates the Knowledge Graph view so node filters can request a server-side
typefiltered graph page, edge filters includeoriginates_fromandcovered_by, and node counters distinguish visible, loaded and total KG nodes. - Adds graph/runtime settings surfaces and diagnostics for KG health, graph database sizing, queue/dead-letter state and historical consolidation.
- Rebuilds and embeds the current frontend assets in the Python package so
okto-pulse serveships the updated 0.2.0 UI.
For a complete history, see the GitHub releases for this repository and okto-pulse-core.
License
Elastic License 2.0 - free for personal and commercial use. You may not provide this software to third parties as a hosted or managed service.
Copyright 2026 Okto Labs
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 okto_pulse-0.2.0.tar.gz.
File metadata
- Download URL: okto_pulse-0.2.0.tar.gz
- Upload date:
- Size: 2.2 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
349c80109e808b7fbc9db219051ace10d929cf0426ebfbbbbb480418ff66dc8d
|
|
| MD5 |
5ab7b31e1bbb8155f52a6ffbbacaba55
|
|
| BLAKE2b-256 |
91a435d212fd4783155a6e43ba30d8891a55e254cd050b7bdda34131aa6b8087
|
File details
Details for the file okto_pulse-0.2.0-py3-none-any.whl.
File metadata
- Download URL: okto_pulse-0.2.0-py3-none-any.whl
- Upload date:
- Size: 2.2 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6def592e9c756e59c2cf5e416f72dd9ff0216f745bcdfb0ab48fa0daba234ca2
|
|
| MD5 |
1d7c5713c74aa3e931e47e0538e6a8c7
|
|
| BLAKE2b-256 |
0b6c4de926fa15f60edf4bff0b3a7655f3c57a44113da941cc7c4a2cb23f31a0
|