988e901066
Añade campos params y output al frontmatter YAML de las 506 funciones del registry. Cada parámetro tiene descripción semántica (qué representa, unidades, rango típico) y cada función describe qué produce su output. Permite a agentes razonar sobre cadenas de composición (ej: prices → log_return → sharpe_ratio) sin leer código.
44 lines
1.5 KiB
Markdown
44 lines
1.5 KiB
Markdown
---
|
|
name: cdp_connect
|
|
kind: function
|
|
lang: go
|
|
domain: browser
|
|
version: "1.0.0"
|
|
purity: impure
|
|
signature: "func CdpConnect(port int) (*CDPConn, error)"
|
|
description: "Se conecta al endpoint CDP en localhost:{port}. Obtiene el webSocketDebuggerUrl via HTTP /json/version, realiza el handshake WebSocket RFC 6455 sobre TCP puro (sin dependencias externas) y retorna una CDPConn lista para usar. Inicia goroutine de lectura de mensajes."
|
|
tags: [chrome, cdp, browser, automation, websocket, devtools]
|
|
uses_functions: []
|
|
uses_types: []
|
|
returns: []
|
|
returns_optional: false
|
|
error_type: "error_go_core"
|
|
imports: [fmt, net, net/url, strings]
|
|
params:
|
|
- name: port
|
|
desc: "puerto del servidor CDP (localhost:{port})"
|
|
output: "(*CDPConn, error): conexión WebSocket lista para usar"
|
|
tested: true
|
|
tests: ["TestChromeLaunchAndConnect"]
|
|
test_file_path: "functions/browser/chrome_launch_test.go"
|
|
file_path: "functions/browser/cdp_connect.go"
|
|
---
|
|
|
|
## Ejemplo
|
|
|
|
```go
|
|
conn, err := CdpConnect(9222)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
defer CdpClose(conn, 0)
|
|
```
|
|
|
|
## Notas
|
|
|
|
El WebSocket se implementa desde cero usando `net.Dial` + handshake HTTP Upgrade + framing RFC 6455. Esto evita dependencias externas. Solo soporta frames no fragmentados (suficiente para CDP que envia mensajes completos).
|
|
|
|
El struct `CDPConn` y toda la infraestructura WebSocket/CDP se define en `cdp_conn.go` dentro del mismo paquete `infra`.
|
|
|
|
La goroutine `readLoop` enruta respuestas a channels por ID de mensaje. Los eventos CDP sin ID son ignorados (las funciones que necesitan eventos usan polling).
|