Files
fn_registry/python/functions/infra/registry_telemetry.md
T
egutierrez 47fac22230 chore: auto-commit (799 archivos)
- .claude/CLAUDE.md
- .claude/commands/subagentes.md
- .claude/rules/INDEX.md
- .mcp.json
- bash/functions/cybersecurity/analyze_dns.md
- bash/functions/cybersecurity/audit_http_headers.md
- bash/functions/cybersecurity/audit_ssh_config.md
- bash/functions/cybersecurity/check_firewall.md
- bash/functions/cybersecurity/detect_suspicious_users.md
- bash/functions/cybersecurity/encrypt_file.md
- ...

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-14 00:28:20 +02:00

57 lines
2.4 KiB
Markdown

---
name: registry_telemetry
lang: py
domain: infra
version: 0.1.0
purity: impure
kind: function
description: "Telemetria de invocaciones del registry desde Python. Patchea via sys.meta_path los paquetes del registry (core, finance, metabase, etc.) y registra cada llamada en call_monitor.operations.db. Activable con FN_TELEMETRY=1. Issue 0085c."
tags: [telemetry, monitoring, registry, import-hook, pendiente-usar]
signature: "install() -> bool"
error_type: "error_go_core"
returns_optional: false
params:
- name: FN_TELEMETRY (env)
desc: "Si vale '1', install() registra el meta_path finder y envuelve cada modulo del registry al importarse. Si no, no-op."
- name: FN_REGISTRY_ROOT (env)
desc: "Override de la raiz del registry. Si no se setea, se descubre walking up desde el archivo del modulo."
- name: CLAUDE_SESSION_ID (env)
desc: "ID de sesion Claude Code, persistido en cada fila de calls. Vacio si no se setea."
output: "True si el finder se instalo, False si FN_TELEMETRY != '1' o si ya estaba instalado."
uses_functions: []
uses_types: []
imports:
- functools
- importlib.abc
- importlib.util
- sqlite3
- sys
- time
example: |
# Activacion en heredoc o app
import os
os.environ["FN_TELEMETRY"] = "1"
import sys, os.path as p
sys.path.insert(0, p.join(os.environ["FN_REGISTRY_ROOT"], "python", "functions"))
import infra.registry_telemetry # auto-install al importarse
from core import filter_list, map_list # automaticamente envueltos
filter_list(lambda x: x > 0, [1, -2, 3]) # registrado en calls
file_path: "python/functions/infra/registry_telemetry.py"
tested: false
notes: |
Patron: meta_path importer (PEP 451). Cuando el agente importa `core`, `finance`, etc.,
el finder intercepta la carga del modulo, deja que el loader real ejecute, y luego
envuelve cada callable definido en el modulo con un decorator que mide duration
y registra en calls (con tool_used='python_wrapper').
Fail-safe: si la BD no existe, INSERT falla, o cualquier excepcion ocurre durante
el wrap, se ignora silenciosamente. NUNCA rompe el codigo cliente.
function_id heuristic: `{name}_py_{domain}` donde domain = nombre del paquete
top-level (`core`, `finance`, etc.). Coincide con convencion del registry
siempre que el paquete top-level se llame igual que el dominio.
Privacidad: solo function_id, duration_ms, success, error_class, type_name del error.
NUNCA args, kwargs, return values. error_snippet truncado a 240 chars.
---