--- name: metabase_create_card_raw kind: function lang: py domain: infra version: "1.0.0" purity: impure signature: "def metabase_create_card_raw(client: MetabaseClient, payload: dict) -> dict" description: "Crea una card en Metabase enviando el payload completo sin modificaciones. Version raw para flujos Metabase-as-code donde el caller construye el body entero. Endpoint: POST /api/card." tags: [metabase, card, question, create, api, python, raw, as-code] uses_functions: [metabase_auth_py_infra] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [httpx] params: - name: client desc: "instancia autenticada de MetabaseClient con sesion activa" - name: payload desc: "dict con el payload completo de la card tal como lo espera la API de Metabase; campos minimos: name, dataset_query, display; campos opcionales preservados: visualization_settings, parameters, parameter_mappings, type, collection_id, description, archived, enable_embedding, embedding_params" output: "dict: objeto card recien creado con id asignado por Metabase y todos los campos normalizados (display, dataset_query, visualization_settings, created_at, etc.)" tested: false tests: [] test_file_path: "" file_path: "python/functions/metabase/cards.py" --- ## Ejemplo ```python card = metabase_create_card_raw(client, { "name": "Revenue by Month", "dataset_query": { "database": 1, "type": "native", "native": {"query": "SELECT date_trunc('month', created_at), SUM(total) FROM orders GROUP BY 1"}, }, "display": "line", "visualization_settings": { "graph.x_axis.title_text": "Month", "graph.y_axis.title_text": "Revenue", }, "description": "Monthly revenue trend", "collection_id": 5, }) print(card["id"]) # ID asignado por Metabase ``` ## Notas No se escriben tests automaticos porque requiere una instancia real de Metabase. Los intentos de mockear `client.request` quedan fuera del alcance del registry por ahora — la validacion se hace en integracion contra un entorno Metabase real. A diferencia de `metabase_create_card`, esta funcion no descarta ni transforma ningun campo del payload: lo envia tal cual al endpoint. Esto permite pasar `visualization_settings`, `parameters`, `embedding_params`, `type`, etc. sin que la funcion los filtre. Si Metabase devuelve 4xx/5xx, httpx lanza `HTTPStatusError` sin capturar. El caller debe manejar errores si necesita recuperacion.