Install Microsoft Fabric agent profiles (Claude Code and Codex) into a target repository.
Project description
Fabric Agent Pack
Vendor-native Codex and Claude Code profiles for Microsoft Fabric data engineering.
Fabric Agent Pack turns a normal git repository into a guided Microsoft Fabric project workspace. It installs agent instructions and lightweight scaffold files, while fabric-vibe provides the setup, validation, notebook, pipeline, lakehouse, and workspace helpers from the package.
This repository is the source package and installer, not the day-to-day Fabric project workspace. Install a profile into your actual project repository, then run Codex or Claude Code from that target repository root.
Overview
Quick start
The CLI is published as fabric-vibecoding-settings on PyPI. Installing it puts two console scripts on your PATH:
| Command | Role |
|---|---|
fabric-vibecoding-agents |
Install / check / refresh agent profiles in a project repo |
fabric-vibe |
Daily Fabric helpers run from a project repo (notebook, pipeline, lakehouse, workspace, lint, precommit) |
Step 1 — Install the CLI
uv tool install fabric-vibecoding-settings # recommended
# or
pip install fabric-vibecoding-settings
Step 2 — Install a profile into your project repo
# preview
fabric-vibecoding-agents install --profile claude --target /path/to/project-repo --dry-run
# apply (also runs fabric-vibe setup: ms-fabric-cli + creds + workspaces.json)
fabric-vibecoding-agents install --profile claude --target /path/to/project-repo
# verify drift later
fabric-vibecoding-agents check --profile claude --target /path/to/project-repo
fabric-vibecoding-agents install copies the profile and scaffold files into the target, then runs fabric-vibe setup from the target root to install ms-fabric-cli, prompt for FABRIC_TENANT_ID / CLIENT_ID / CLIENT_SECRET, verify auth, and populate workspaces.json. Pass --no-bootstrap to skip.
Step 3 — Daily work inside the project
Once a profile is installed, run the daily helpers via fabric-vibe from the project root:
fabric-vibe notebook build <name>
fabric-vibe notebook deploy <name> <workspace_id>
fabric-vibe pipeline manage list
fabric-vibe lakehouse list-tables
fabric-vibe workspace switch <displayName>
fabric-vibe lint
fabric-vibe precommit
Each subcommand passes its trailing argv through to package-bundled helpers while preserving the target repo as the working directory. Use fabric-vibe <group> --help to see what each helper accepts.
fabric-vibecoding-agents flags
| Flag | Effect |
|---|---|
--profile {codex,claude,all} / -p |
Pick the agent profile (required) |
--target <path> / -t |
Target git repository (required) |
--dry-run |
Preview changes without writing (install/refresh only) |
--force |
Overwrite non-managed existing files |
--backup |
Back up replaced files alongside the originals |
--no-bootstrap |
Copy files only; skip the post-install Fabric auth + workspaces.json bootstrap (install only) |
--verbose / -v |
Debug-level logging |
--quiet / -q |
Suppress info logging |
--help / -h |
Show usage |
Service-principal credentials
Minimum Fabric workspace role: Contributor. The bootstrap prompts for these and stores them safely:
| Prompt | Stored where |
|---|---|
FABRIC_TENANT_ID |
<target>/.env |
FABRIC_CLIENT_ID |
<target>/.env |
FABRIC_CLIENT_SECRET |
OS environment only — never .env |
On Windows the secret is written to the user registry via SetEnvironmentVariable("User"). On Linux/macOS it is appended to your shell profile (~/.zprofile, ~/.bash_profile, or ~/.profile).
Create the service principal once, before running setup:
Azure Portal → App registrations → New registration
Name: fabric-agent-<project>
Supported account types: this tenant only
Fabric workspace → Manage access → Add → service principal
Role: Contributor
Re-running the same install command is idempotent — credentials already set are skipped, and managed files only change when their source content changes. If you need to bootstrap again later (e.g. after rotating the secret), run fabric-vibe setup from inside the target.
Docker image
The Fabric MCP server is also published as a Docker image on Docker Hub:
docker pull silviocardoso/fabric-vibecoding-mcp-server:latest
Image page: silviocardoso/fabric-vibecoding-mcp-server
The image builds from server/Dockerfile and includes the server-side MCP tools plus the baked knowledge-graph artifacts. Use it when you want to run the MCP server from a published image instead of building it locally with docker compose up --build.
Minimal docker-compose.yml using the published image:
services:
server:
image: silviocardoso/fabric-vibecoding-mcp-server:latest
container_name: fabric-mcp-server
environment:
PORT: "8000"
HOST: "0.0.0.0"
LOG_LEVEL: ${LOG_LEVEL:-info}
ports:
- "127.0.0.1:8000:8000"
restart: unless-stopped
Then start it with:
docker compose up
This binds the server to 127.0.0.1:8000, so it is reachable from your machine without exposing it to the LAN.
Learn more
- docs/workflow.md — agent → skill → tool → Fabric flow, focused on what you get in the target repo.
- docs/knowledge-graph.md — what's indexed under
memory/and thegraph_*MCP surface the agents call. - docs/architecture.md — full source-vs-target picture: MCP servers, folder layout, setup CLI, and the redesign migration notes.
Example result
The screenshots below show an end-to-end bronze ingestion of EU day-ahead electricity prices into a Fabric Lakehouse.
1 — Authoring the bronze notebook
The developer agent authors bronze_electricity_day_ahead_prices.py while the upstream download_sources job runs in Fabric.
2 — Deploying and triggering
Codex reads the workspace ID from .env, deploys the notebook through the Fabric REST API, and triggers the run.
3 — Full run history
The Fabric Monitor shows download_sources → bronze_electricity_day_ahead_prices → dq_bronze_electricity_day_ahead_prices succeeding after schema-contract iterations.
4 — Ingested Delta table
The resulting Delta table contains 1,000 rows and 27 columns, including lineage envelope fields such as _ingest_timestamp, _source_system, and _batch_id.
5 — Restricted workspace for AI agentic development
The agent runs in a dedicated workspace. Permissions are set at the workspace level to ensure there is no access to production data or pipelines.
6 — Development Lifecycle
The code is integrated with Git, and the agent develops everything in a dedicated feature branch. Human developers can review the pull request later and merge the work from the feature branch into dev.
Note: The VIBECODING workspace was set up by selecting individual Fabric items. This narrowed down the codebase to only the scripts that stakeholders actually care about.
Live reference implementation
fabric-open-data-lu is a public target repository with Claude- and Codex-generated scripts for EU open-data ingestion into Microsoft Fabric. It demonstrates the download_ → bronze_ → dq_bronze_ notebook pattern used by this package.
Why use it?
- Ship faster — agents handle notebook authoring, deployment, schema validation, and pipeline wiring. Engineers own approvals and production handoffs.
- OWASP-compliant by default — Data Security Top 10 and Supply Chain (A03:2025) baked in: no credential leakage, parameterized queries, pinned dependencies, CVE checks, PII masking.
- Harness engineering — agents run inside a structured harness of guardrails, role definitions, skill boundaries, and memory. Consistent, auditable behavior without custom prompt engineering per project.
- Separation of duties — implementation, testing, and security review are distinct agents. Nothing reaches production without a human sign-off.
- Quality gates at every layer — mandatory Great Expectations checks at bronze, silver, and gold. Failed DQ stops the pipeline; agents do not auto-retry.
- Token savings — RTK optimizer cuts shell-output tokens 60–90%, keeping long sessions economical.
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 fabric_vibecoding_settings-0.1.tar.gz.
File metadata
- Download URL: fabric_vibecoding_settings-0.1.tar.gz
- Upload date:
- Size: 176.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
546b2b7a982b68be4c2f694329f212a3f4671f9d377ae9d72dde16b06705cf16
|
|
| MD5 |
587f06a3c361f651800f71bd8dd1cacb
|
|
| BLAKE2b-256 |
ab667a1d97d5aacd7c206e3425ae99a51133d0e9c0ff0a9c168f48970c7b12c8
|
Provenance
The following attestation bundles were made for fabric_vibecoding_settings-0.1.tar.gz:
Publisher:
python-publish.yml on scardoso-lu/fabric-skills-settings
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fabric_vibecoding_settings-0.1.tar.gz -
Subject digest:
546b2b7a982b68be4c2f694329f212a3f4671f9d377ae9d72dde16b06705cf16 - Sigstore transparency entry: 1635429613
- Sigstore integration time:
-
Permalink:
scardoso-lu/fabric-skills-settings@fe8e53200f055c93498737872339381079663a66 -
Branch / Tag:
refs/tags/v0.1 - Owner: https://github.com/scardoso-lu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@fe8e53200f055c93498737872339381079663a66 -
Trigger Event:
release
-
Statement type:
File details
Details for the file fabric_vibecoding_settings-0.1-py3-none-any.whl.
File metadata
- Download URL: fabric_vibecoding_settings-0.1-py3-none-any.whl
- Upload date:
- Size: 90.7 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 |
a43263cc5d96f153d187f9f49c8289138e38f11d4a7c63c67d45069b2040fc9b
|
|
| MD5 |
2fe15d35af5848e1384d2834fabdf1ec
|
|
| BLAKE2b-256 |
57add885cca71f36ae2d5b2295626146e18b568661619eea898c3ddc34d6f037
|
Provenance
The following attestation bundles were made for fabric_vibecoding_settings-0.1-py3-none-any.whl:
Publisher:
python-publish.yml on scardoso-lu/fabric-skills-settings
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fabric_vibecoding_settings-0.1-py3-none-any.whl -
Subject digest:
a43263cc5d96f153d187f9f49c8289138e38f11d4a7c63c67d45069b2040fc9b - Sigstore transparency entry: 1635429617
- Sigstore integration time:
-
Permalink:
scardoso-lu/fabric-skills-settings@fe8e53200f055c93498737872339381079663a66 -
Branch / Tag:
refs/tags/v0.1 - Owner: https://github.com/scardoso-lu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@fe8e53200f055c93498737872339381079663a66 -
Trigger Event:
release
-
Statement type: