Metabase serdes-workflow
Export content from a running Metabase instance, validate with checkers, edit YAML, and import back. Use when the user wants to export, import, or run the full serdes round-trip workflow.
git clone https://github.com/metabase/metabase
T=$(mktemp -d) && git clone --depth=1 https://github.com/metabase/metabase "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/serdes-workflow" ~/.claude/skills/metabase-metabase-serdes-workflow && rm -rf "$T"
.claude/skills/serdes-workflow/SKILL.mdSerdes Workflow Skill
End-to-end workflow for exporting Metabase content as YAML, validating it, editing it, and importing it back.
Prerequisites
All commands require the
:ee alias since export, import, and checkers live in enterprise code.
You need
MB_DB_CONNECTION_URI set to point at the target Metabase Postgres database when importing. The running dev instance's connection string is in the worktree environment (check the nREPL or startup output).
Export
clojure -M:run:ee export /path/to/export-dir
Flags:
- export only specific collection IDs-c 123,456
- include field values-f
- continue on error-e
This writes YAML files in the serdes directory layout:
databases/<db-name>/<db-name>.yaml databases/<db-name>/schemas/<schema>/tables/<table>/<table>.yaml databases/<db-name>/schemas/<schema>/tables/<table>/fields/<field>.yaml collections/<eid>_<slug>/cards/<eid>_<slug>.yaml
Validate
Always run both checkers after any modification. They skip full Metabase startup (~8s each).
Structural checker (fast, schema-based)
clojure -M:run:ee --mode checker --checker structural --export /path/to/export-dir
Validates YAML shapes against Malli schemas. Catches typos, missing required fields, wrong types.
Cards checker (query validation)
clojure -M:run:ee --mode checker --checker cards --export /path/to/export-dir
Validates that card queries resolve correctly against exported metadata (tables, fields, FKs). Uses MLv2 under the hood.
Additional cards checker flags:
- fabricate metadata on demand (when no database schema files exist)--lenient
- write manifest of all referenced entities (lenient mode only)--manifest /path/to/manifest.yaml
- write detailed results to file--output /path/to/results.edn
Edit YAML
See the serdes-yaml-edit skill for guidance on editing YAML files. The critical rule: run both checkers after every edit before proceeding.
Import
MB_DB_CONNECTION_URI="postgres://user:pass@localhost:5432/metabase_dbname" \ clojure -M:run:ee import /path/to/export-dir -e
The
-e flag continues on error. The MB_DB_CONNECTION_URI must point at the same Postgres database the running Metabase instance uses - without it, import defaults to H2 which is wrong.
Full Demo Sequence
- Export:
clojure -M:run:ee export /tmp/metabase-export - Validate baseline: run both checkers
- Edit YAML files (see serdes-yaml-edit skill)
- Re-validate: run both checkers again
- Import:
MB_DB_CONNECTION_URI=... clojure -M:run:ee import /tmp/metabase-export -e - Verify in browser