Your agents generate, deploy, and govern dashboards from any database, grounded in a context layer they can actually trust.
π£ 2026-05-07: Wren Engine has merged into this repo under
core/. The previousCanner/wren-enginerepo is archived. The previous WrenAI GenBI app (the Docker-based chat-first BI product) is preserved on thelegacy/v1branch (tagv1-final) and is now Wren GenBI Classic; see A note on the "GenBI" name below. Read the announcement β
WrenAI is the open-source GenBI engine: it lets AI agents generate, deploy, and govern business intelligence, from a SQL answer to a shareable dashboard, across 22+ data sources.
What makes the output trustworthy is the layer underneath: an open context layer that gives agents what schemas don't. That means business semantics, approved definitions, examples, memory, and governance, plus the unstructured company knowledge that lives in your docs, wikis, and chat threads. Generative BI is only as good as the context it stands on, and Wren is that context, made reviewable and reusable by every agent you already run.
- Generate. Your agent turns a business question into governed SQL and charts. Schema-aware retrieval, MDL planning, dry-plan validation, and structured errors keep it correct instead of confidently wrong.
- Deploy. Turn any answer into a shareable, browser-side dashboard powered by
wren-core-wasmand ship it to your own Vercel or Cloudflare Pages account with one command. - Know. The knowledge that makes all of this correct lives in versionable, evidence-linked files: semantic models (MDL), company definitions (
instructions.md), and a memory of what worked. Reviewable. Git-friendly. Never locked inside someone else's UI.
- Generative BI, end to end. Not just text-to-SQL. Generate the answer, deploy the dashboard, share the URL, all driven by the agents you already use.
- Knowledge management built in. Business meaning, approved definitions, and proven examples are captured as reviewable, version-controlled context, not buried in prompts.
- Open by default. Open-sourced core, SDK, and skills under the Apache-2.0 license.
- Correctness as primitives. Rich schema retrieval, dry-plan validation, structured errors with hints, value profiling, eval runner. The agent orchestrates; the trace lives in its reasoning.
- Sits on top of your existing stack. Warehouse, transformation pipelines, your existing semantic layer. Not another tool to maintain.
| A raw LLM agent | A traditional BI tool | A bare semantic layer | WrenAI | |
|---|---|---|---|---|
| Writes SQL for you | β (often wrong) | β | β | β governed |
| Knows your business definitions | β | partial, in-tool | β (schema only) | β + non-schema knowledge |
| Generates & deploys dashboards | β | β (manual, in-tool) | β | β agent-driven |
| Works through your agents (Claude Code, Cursor, MCPβ¦) | β | β | β | β |
| Open, reviewable, Git-friendly context | β | β | partial | β |
| Governed execution across 22+ sources | β | per-connector | β (definitions only) | β |
- You want AI agents to produce trustworthy BI, answers and dashboards, not just plausible SQL.
- Your business logic (definitions, enums, units, approved joins) lives outside the database and your agents keep getting it wrong.
- You want context that's open, reviewable, and version-controlled, usable by every agent and person, not gated behind one vendor's UI.
Skip Wren if you only need a one-off chart from a single CSV, or you're happy letting an agent guess at SQL with no governance.
WrenAI is agent-driven by design: install the CLI, install a one-file discovery stub for your AI client, then let your AI agent drive the rest. Workflow guides live inside the CLI itself and are served on demand, so content always matches the installed version.
pip install wrenai # core (DuckDB included)
pip install "wrenai[postgres,memory]" # add per-datasource and memory extras as neededTip for users in mainland China: If
pip installis slow or fails, use the Tsinghua mirror:pip install wrenai -i https://pypi.tuna.tsinghua.edu.cn/simpleIf HuggingFace model downloads time out, add
export HF_ENDPOINT=https://hf-mirror.combefore running the CLI.
npx skills add Canner/WrenAI # auto-detects Claude Code, Cursor, Cline, Codex, β¦The stub is ~50 lines. It teaches your agent to fetch workflow guides via
wren skills get <name> and shaped prompts via
wren ask "<question>" --guided|--direct, and everything else lives in the CLI.
Open your agent in a project directory and say something like:
"Use Wren to set up my Postgres database."
The agent runs wren skills get onboarding, follows the guide step-by-step,
checks your environment, creates a connection profile, scaffolds the project,
and runs a first query.
Once onboarding finishes, ask:
"Enrich my Wren project with the business context in
raw/."
The agent runs wren skills get enrich-context and follows the guide in
grill mode (one question at a time) or auto-pilot mode (agent reads
<project>/raw/ and proposes). Both modes write to MDL, instructions,
queries, and memory, all reviewable, all Git-friendly.
"Who are our top 10 customers by sales this quarter?"
Your agent fetches MDL context, recalls similar past queries, writes
governed SQL, and executes via wren query.
"Turn that into an interactive dashboard I can filter and share, and deploy it to Vercel."
The agent runs wren skills get genbi, builds a browser-side GenBI app from
your project's context, previews it locally, and ships it to your own Vercel
or Cloudflare Pages account, returning a live, shareable URL. See the
Build & deploy a GenBI app guide.
Want to try it without your own database? Ask your agent to use the
bundled jaffle_shop sample dataset. Same flow, querying a real warehouse
end-to-end in a couple of minutes.
# Day 1 (agent-driven)
wren skills get onboarding # workflow guide: set up project + first query (Generate)
wren skills get enrich-context # workflow guide: add business context (Know)
wren skills get genbi # workflow guide: build & deploy a dashboard (Deploy)
# Day-to-day
wren query --sql '...' # query through the MDL semantic layer
wren ask "<question>" --guided # wrap a question for a weaker agent
wren ask "<question>" --direct # wrap a question for a stronger agentFast at first. Deep when you need it. Always reviewable and Git-friendly.
- Modeling Definition Language (MDL): models, columns, relationships, views, cubes, metrics, row-level / column-level access control (RLAC / CLAC)
- Engine: Apache DataFusion based, 22+ data sources
- GenBI dashboards: agent-built, browser-side apps powered by
wren-core-wasm, deployable to Vercel / Cloudflare Pages - Knowledge & memory: business meaning in version-controlled
instructions.mdandqueries.yml, plus a local LanceDB memory index (hybrid retrieval) for recall - Agent SDK:
wren-langchain(LangChain / LangGraph),wren-pydantic; reference Python integration for other stacks - Governed execution primitives: functions, dry-plan, row limits, access control
- End-to-end correctness primitives: value profiling, rich retrieval, structured errors, golden eval runner
- Agent-native distribution: first-class SDKs across major agent frameworks; see GitHub Discussions for what's prioritized next
- Full governed execution: audit logs, rate limits, approval workflow, data-flow inspector
Full roadmap and design notes: see the introduction.
"GenBI" now refers to this open-source generative-BI capability: agents that
generate governed answers and deploy dashboards on top of Wren's context
layer. The earlier Wren AI GenBI app, the Docker-based chat-first BI
product, is now Wren GenBI Classic, preserved on the
legacy/v1 branch (no new
features or security fixes). For a maintained, hosted version of that classic
experience, see Wren AI Commercial.
- Quickstart: from skill install to first answer
- Build & deploy a GenBI app: generate a dashboard and ship it
- Concepts: what context is, what MDL is, how memory works
- Connect a database: Postgres, BigQuery, Snowflake, DuckDB, and more
- Agent SDKs: what's shipping today, what's next
- π¬ Discord: chat with the team and other builders
- π GitHub Discussions: design conversations, RFCs, longer threads
- π¦ Twitter / X: release notes and short updates
- π Blog: vision, post-mortems, deep dives
We build in the open. Issues, PRs, connector contributions, SDK integrations, docs fixes are all welcome.
- Contributor guide
- Connector ecosystem program: three-tier ownership (official, community-blessed, community-owned)
- Architecture map: find the right place to land your change
- Looking for somewhere to start? Try the
good first issuelabel.
Project structure (click to expand)
core/
wren-core/ Rust semantic engine (Apache DataFusion)
wren-core-base/ Shared manifest types + MDL builder
wren-core-py/ Python bindings (PyPI: wren-core)
wren-core-wasm/ WebAssembly build (npm: wren-core-wasm)
wren/ Python SDK and CLI (PyPI: wrenai)
wren-mdl/ MDL JSON schema
sdk/
wren-langchain/ Reference agent SDK integration
skills/ Agent skills for context authoring
docs/ Module documentation
examples/ Example projects
Apache 2.0. See LICENSE.
Come build open GenBI with us.
If WrenAI helps you, drop a β, it genuinely helps us grow!
