Agent-native analytics. One schema, many surfaces.
Docs · Getting Started · Changelog · Discord · Website
BI tools serve one UI. Bonnard serves everything. Agents over MCP, apps over SDK, dashboards in markdown, internal tools via REST. One set of metric definitions, every consumer gets the same governed answer.
Traditional semantic layers were built for dashboards and retrofitted for AI. Agents get different answers than dashboards, metrics drift across tools, and every new surface means another integration. Bonnard was built agent-native from day one. MCP is a core feature, not a plugin. One CLI, one schema, every consumer gets the same governed answer.
No install required. Run directly with npx:
npx @bonnard/cli initOr install globally:
npm install -g @bonnard/cliThen follow the setup flow:
bon init # Scaffold project + agent configs
bon datasource add # Connect your warehouse
bon validate # Check your models locally
bon login # Authenticate
bon deploy -m "initial deploy" # Ship itYour semantic layer is now live. Agents, dashboards, and the SDK all query the same governed metrics.
No warehouse yet? Start exploring with a full retail demo dataset:
bon datasource add --demoRequires Node.js 20+.
- Agent context out of the box.
bon initgenerates rules and skills for Claude Code, Cursor, and Codex so agents understand your semantic layer from the first prompt. - MCP server for governed agent queries. Set up with
bon mcp, test withbon mcp test. - Markdown dashboards with BigValue, LineChart, BarChart, AreaChart, PieChart, and DataTable components. Preview locally with
bon dashboard dev, deploy withbon dashboard deploy. - JSON and SQL querying from the terminal via
bon queryandbon schema, or programmatically via the REST API. - Deployment versioning with change tracking (
bon diff), annotations (bon annotate), and full history (bon deployments). - CI/CD support. Run
bon deploy --ci -m "message"for non-interactive pipelines.
Warehouses: Snowflake (including Snowpark), Google BigQuery, Databricks (SQL warehouses and Unity Catalog), PostgreSQL (including Supabase, Neon, and RDS), Amazon Redshift, DuckDB (including MotherDuck)
Data tools: dbt (model and profile import), Dagster, Prefect, Airflow (orchestration), Looker, Cube, Evidence (existing BI layers), SQLMesh, Soda, Great Expectations (data quality)
Bonnard auto-detects your warehouses and data tools. Point it at your project and it discovers schemas, tables, and relationships.
- @bonnard/sdk: query the semantic layer from any JavaScript or TypeScript application
- @bonnard/react: React chart components and a markdown dashboard viewer
| Command | Description |
|---|---|
bon init |
Scaffold a new project with agent configs |
bon datasource add |
Connect a data source (or --demo for sample data) |
bon validate |
Validate YAML syntax locally |
bon deploy -m "message" |
Deploy to production |
bon pull |
Download deployed models to local project |
bon query |
Run queries (JSON or SQL) |
bon schema |
Explore deployed measures, dimensions, and views |
bon dashboard dev |
Preview a markdown dashboard locally |
bon dashboard deploy |
Deploy a dashboard |
bon mcp |
MCP server setup instructions |
bon keys create |
Create a publishable or secret API key |
bon docs |
Browse documentation from the CLI |
See the full CLI reference for all commands and flags.
| Guide | Description |
|---|---|
| Getting Started | From zero to deployed in minutes |
| CLI Reference | Every command, flag, and option |
| Modeling Guide | Cubes, views, metrics, and dimensions |
| Dashboards | Markdown dashboards with charts, inputs, and theming |
| SDK | TypeScript SDK and React components |
| Querying | JSON and SQL query syntax |
| Changelog | What shipped and when |
- Discord: ask questions, share feedback, connect with the team
- GitHub Issues: bug reports and feature requests
- LinkedIn: follow for updates
- Website: learn more about Bonnard
Contributions are welcome. If you find a bug or have an idea, open an issue or submit a pull request.