Files
fn_registry/python/functions/metabase/metabase_create_model.md
T
egutierrez 58539f45c9 feat(metabase): expansion cards y documents — export, model, ProseMirror validation, copy nativo
Cards: export_card (CSV/XLSX/JSON), create_model (type=model para fuentes MBQL).
Documents: prosemirror_card_embed helper (resizeNode envolviendo cardEmbed),
validacion automatica contra whitelist TipTap antes de enviar, copy_document
refactorizado al endpoint nativo POST /api/document/:id/copy.
Docs: dataset_query legacy vs MBQL5, template-tags, whitelist de nodos.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-14 19:03:19 +02:00

2.3 KiB

name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
name kind lang domain version purity signature description tags uses_functions uses_types returns returns_optional error_type imports params output tested tests test_file_path file_path
metabase_create_model function py infra 1.0.0 impure def metabase_create_model(client: MetabaseClient, name: str, sql: str, database_id: int, collection_id: int = 0, description: str = '') -> dict Crea un modelo de Metabase (card con type='model') que otras cards MBQL pueden usar como fuente via source-table: 'card__<id>'.
metabase
model
card
create
api
python
false error_go_core
httpx
name desc
client instancia autenticada de MetabaseClient
name desc
name nombre del modelo
name desc
sql query SQL que define el modelo
name desc
database_id ID de la database en Metabase donde vive la query
name desc
collection_id ID de coleccion destino; 0 = root
name desc
description descripcion opcional del modelo
dict con el modelo creado: id, name, type='model', dataset_query y metadata completa false
python/functions/metabase/cards.py

Ejemplo

# Crear modelo base
model = metabase_create_model(
    client,
    name="supply_orders_base",
    sql="SELECT * FROM supply_orders WHERE status != 'cancelled'",
    database_id=6,
    collection_id=42,
    description="Ordenes de supply excluyendo canceladas",
)
print(model["id"])  # ej: 7820

# Usar el modelo como fuente en una card MBQL
card = metabase_create_card(client, "Revenue por proveedor", {
    "database": 6,
    "type": "query",
    "query": {
        "source-table": f"card__{model['id']}",
        "aggregation": [["sum", ["field", "total", None]]],
        "breakout": [["field", "supplier_id", None]],
    },
}, display="bar")

Notas

Un modelo es una card con type="model". Metabase lo trata como una capa de abstraccion — las cards MBQL que lo referencian via source-table: "card__<id>" se benefician del schema inferido del modelo (tipos de columna, foreign keys, etc.).

A diferencia de metabase_create_card, esta funcion fuerza type="model" y siempre usa query SQL nativa. Para modelos MBQL o con configuracion avanzada (result_metadata, column types), usar metabase_create_card_raw con type="model" en el payload.