--- name: metabase_add_membership kind: function lang: py domain: infra version: "1.0.0" purity: impure signature: "def metabase_add_membership(client: MetabaseClient, user_id: int, group_id: int, is_group_manager: bool = False) -> list[dict]" description: "Añade un usuario a un Permission Group de Metabase. Endpoint: POST /api/permissions/membership. Retorna la lista completa de membresías del grupo tras la operación." tags: [metabase, permissions, membership, groups, users, api, python] uses_functions: [] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [] params: - name: client desc: "instancia autenticada de MetabaseClient con permisos de superusuario" - name: user_id desc: "ID numérico del usuario a añadir al grupo" - name: group_id desc: "ID numérico del grupo destino" - name: is_group_manager desc: "si True, el usuario obtiene rol de manager del grupo (puede gestionar sus miembros)" output: "list[dict]: lista de todas las membresías actuales del grupo tras la operación. Cada elemento contiene membership_id, user_id, group_id, is_group_manager" tested: false tests: [] test_file_path: "" file_path: "python/functions/metabase/permissions.py" --- ## Ejemplo ```python # Añadir usuario como miembro regular members = metabase_add_membership(client, user_id=5, group_id=3) print(len(members), "miembros en el grupo") # Añadir como manager del grupo members = metabase_add_membership(client, user_id=5, group_id=3, is_group_manager=True) ``` ## Notas Metabase responde con la lista completa de membresías del grupo (no solo la nueva). Lanza HTTPStatusError 400 si el usuario ya es miembro del grupo. El `membership_id` de la entrada creada está en el elemento nuevo de la lista retornada.