Skip to main content

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.

PyPI version Python versions License Core repository


Table of Contents

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.1 surface:

Surface Count
Governance gates 15
Core MCP tools 204
Community-only MCP tools 0
MCP tools exposed by okto-pulse serve 204

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-v2 sentence-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.json that 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 done require 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.2 - current

Patch release rolling up four targeted fixes on top of 0.2.1. Same surface, no migration needed.

  • Sprint Scope tab now renders Integration Requirements and Observability Requirements alongside FR/TR/AC/BR/contracts/scenarios. The SprintModal.tsx source already had the two ScopeSection blocks for IR and OR, but the published 0.2.1 bundle had been built before that change reached the source tree — so the two sections were silently missing from the UI even though the backend was returning them. feature/0.2.2 ships a rebuilt frontend_dist/ and verifies the parity in the Sprint Scope tab via a live Playwright check on [E2E-IR-OR-PARITY] Sprint 1.
  • okto-pulse serve no longer gets stuck behind a stale lock after a crash or reboot. ServeInstanceLock now stamps a periodic heartbeat_at (every 30s by default, TTL 120s) and accepts the lock as orphaned when the heartbeat is stale — even if the recorded PID is still alive, since the operating system may have recycled that PID after a hard restart. Legacy lock files written by a pre-heartbeat version fall back to the existing PID-only liveness check, so upgrading is safe. The operator-facing error message now tells you to wait for the TTL to elapse instead of having to delete the file manually.
  • Inherited okto-pulse-core SDLC E2E gate polish from feature/0.2.2submit_spec_validation now runs the AC → test-scenario coverage gate as a pre-requisite (so uncovered ACs no longer trap a spec inside a successful validation lock); the "FR has no business rule" error message uses an [i] index marker instead of the duplicated FR1: FR2: label; okto_pulse_link_task target_type='decision' returns the saturation envelope like the other six target types; and okto_pulse_evaluate_ideation documents the status='evaluating' pre-requisite up front.
  • Guided help follow-ups + sprint modal touch-ups — refinements to the guided help engine (skip-all clearing, restart flow, anchoring inside modals and overlays), small SprintModal additions, knowledge empty-state polish, header/agents-modal tweaks. The packaged frontend_dist/ was rebuilt to ship all of the above together.

0.2.1

Branch changelog for feature/0.2.1:

  • Bumps the community package to 0.2.1 and refreshes the embedded frontend bundle so okto-pulse serve ships the current UI directly from the Python package.
  • Adds local-first product metrics: opt-in prompt, Metrics settings panel, local-only/disabled/anonymous-beacon modes, local event storage, export/purge/status CLI commands and an hourly anonymous beacon path guarded by explicit consent.
  • Adds a serve lock for the local data directory. okto-pulse serve now detects an existing server for the same DATA_DIR and refuses to start a second process that could make the embedded Knowledge Graph look empty or lose semantic links.
  • Extends board settings with spec resource automation controls, including explicit toggles for auto-deriving Knowledge Base, Architecture and Mockup resources from specs into downstream work.
  • Adds first-class Integration Requirements (IR) and Observability Requirements (OR) to the spec UI, including dedicated tabs, markdown export, REST client types, permission-aware display and task coverage/linking surfaces.
  • Hardens the Architecture editor with a visual registry, semantic normalization, Excalidraw import preflight, payload validation, light/dark visual regression snapshots and safer diagram rendering.
  • Adds the guided help engine: tour registry, contextual popovers, anchor positioning, persistent progress, telemetry events and the Help -> Guided tours surface for Replay, Reset, Skip step and Skip all flows.
  • Fixes the guided help restart and anchoring path after validation: the Help panel now opens directly on Guided tours, Restart all is visible, Skip all can be cleared globally, and popovers anchor correctly inside modals, overlays and dynamic or empty-state surfaces.
  • Adds verified tours for Board navigation, Spec resources, Task validation, Metrics, Agents, Knowledge Graph and Help. The final served bundle was checked with Playwright screenshots under .codex-artifacts/guided-help/.
  • Updates the packaged frontend assets again after the guided-help fixes so the installed frontend_dist and the source build are aligned.
  • Pulls in the okto-pulse-core 0.2.1 engine changes: first-class IR/OR data model and permissions, service-layer spec resource propagation, local-first telemetry, consolidated MCP list handlers, lazy MCP resources, schema-generation pilot, activity-log cursor pagination and regression coverage.
  • Inherits the okto-pulse-core SDLC E2E gate polish from the same branch: submit_spec_validation now runs the AC → test-scenario coverage gate as a pre-requisite (so uncovered ACs no longer trap a spec inside a successful validation lock); the "FR has no business rule" error message uses an [i] index marker instead of the duplicated FR1: FR2: label; okto_pulse_link_task target_type='decision' returns the saturation envelope like the other six target types; and okto_pulse_evaluate_ideation documents the status='evaluating' pre-requisite up front. See okto-pulse-core CHANGELOG for details.
  • Hardens the okto-pulse serve single-instance guard against stale lock files left by abrupt shutdowns. The lock now writes a periodic heartbeat_at timestamp (every 30s by default) and a fresh acquirer treats a lock with a heartbeat older than the TTL (120s by default) as orphaned — even if the recorded PID is still alive, since the operating system may have recycled that PID after a reboot. Legacy locks without a heartbeat fall back to the previous PID-only check, so upgrading from an older version is safe. Operators who run into the error now see the heartbeat TTL in the message and can wait it out instead of having to delete the lock file manually.

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_evidence fallback data directly from the card.
  • Updates the Knowledge Graph view so node filters can request a server-side type filtered graph page, edge filters include originates_from and covered_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 serve ships 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

okto_pulse-0.2.2-py3-none-any.whl (2.2 MB view details)

Uploaded Python 3

File details

Details for the file okto_pulse-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: okto_pulse-0.2.2-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

Hashes for okto_pulse-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f79421461e2df5a2541c11363800bff0c71ff6d32755c697591ea5c502ee5698
MD5 0f0006f0cd56f5fd03dd370afdd062ee
BLAKE2b-256 2c32f0c6bf7113b628efc829bff6e0431aa407b9f5d0e5530f3d0f10129d707f

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