feat(navegator_dashboard): v1+v2 — CDP HTTP client, real Tabs panel, full Network panel
CDP HTTP client (cdp_http.h/cpp): WinSock raw + crude_json. GET /json/version,
/json (list tabs), PUT /json/new (Chrome 137+), GET /json/activate/{id},
/json/close/{id}.
CDP WebSocket client (cdp_ws.h/cpp): RFC 6455 handshake + framing manual,
masked client frames, async dispatcher con queue + wait_response. Soporta
fragmentacion (FIN=0 + continuation), ping/pong, close frame. Stats bytes
in/out + frames in.
Cross-panel session (session_state.h/cpp): selected_browser_port +
selected_tab_id. Cambiar tab cierra/abre NetworkSession.
Tabs panel: real. List + filtro titulo/URL + Refresh + New tab + Focus +
Close + Select (alimenta Network panel).
Network panel: DevTools-like.
- Tabla: Name | Status (color) | Method | Type | Initiator | Size | Time | Waterfall
- Filtros: text + invert + chips (Doc/CSS/JS/XHR/Img/Media/Font/WS/Other) + All toggle
- Toggles: Preserve log, Disable cache, Hide data:, Only failed, Pause/Resume
- Detalle por request: Headers (general + req + res) | Payload | Response (lazy
Network.getResponseBody) | Cookies | Timing | WS Messages (frames in/out)
- Right-click row: Copy URL / Copy as cURL / Copy as fetch
- Status bar: N requests | bytes transferred | resources | Finish | DCL | Load
- Export HAR 1.2 a archivo junto al exe
NetworkSession parsea Network.requestWillBeSent + ExtraInfo, responseReceived
+ ExtraInfo, dataReceived, loadingFinished, loadingFailed, webSocketCreated,
webSocketFrameSent/Received/Closed, Page.frameNavigated (autoclear si !preserve),
domContentEventFired, loadEventFired.
API local extendida (local_api.cpp):
- GET /browser/{port}/version
- GET /browser/{port}/tabs
- POST /browser/{port}/tab/new?url=
- POST /browser/{port}/tab/{id}/focus
- POST /browser/{port}/tab/{id}/close
- GET /browser/{port}/har (HAR 1.2 export de la sesion activa)
Build:
- CMakeLists.txt linka imgui_node_editor solo para reusar crude_json (sin
codigo de node-editor en runtime).
- 15 MB exe Windows. Cross-compile mingw-w64 OK.
app.md: bump version 0.2.0 -> 0.3.0, panels matrix actualizado, e2e_checks
añade api_health + api_browsers (warning).
Issue 0002 (sub-issue del roadmap navegator_dashboard 0001).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,65 @@
|
||||
#pragma once
|
||||
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
// Panel Chat — agente Claude (claude -p) con tool-use sobre operations.db
|
||||
// via gx-cli. Subprocess persistente bidireccional (stdin/stdout JSON-lines).
|
||||
// El usuario escribe, el hilo lector parsea stream-json y va emitiendo
|
||||
// fragmentos al historial. gx-cli muta operations.db; el contador
|
||||
// agent_mutations en graph_explorer.db dispara reload del viewport.
|
||||
|
||||
namespace app_agent {
|
||||
|
||||
// Inicia el subprocess claude -p (lazy: hasta el primer mensaje no se
|
||||
// arranca). Setea env vars GX_OPS_DB / GX_APP_DB / GX_APP_DIR. Devuelve
|
||||
// false si claude no esta disponible (o, en Windows, wsl no esta).
|
||||
bool chat_init(const char* ops_db_path,
|
||||
const char* app_db_path,
|
||||
const char* app_dir);
|
||||
|
||||
// Si la ops_db cambia (proyecto switch), refresca env del subprocess
|
||||
// matandolo y dejando que el siguiente send lo reabra.
|
||||
void chat_set_ops_db(const char* ops_db_path);
|
||||
|
||||
// Envia un mensaje del usuario al agente. Si el subprocess no esta vivo,
|
||||
// lo arranca primero. No bloquea — el resultado llega via chat_render
|
||||
// al ir vaciando la cola del hilo lector.
|
||||
void chat_send(const char* user_text);
|
||||
|
||||
// Renderiza el panel ImGui (titulo "Chat"). Drena cola de mensajes del
|
||||
// hilo lector. `panel_open` es bound al close button.
|
||||
void chat_render(bool* panel_open);
|
||||
|
||||
// Cierra el subprocess y libera recursos. Llamar en shutdown.
|
||||
void chat_shutdown();
|
||||
|
||||
// Counter de mutaciones (lee tabla agent_mutations en app_db). Se llama
|
||||
// desde main.cpp cada frame para detectar si gx-cli muto algo y disparar
|
||||
// reload del grafo. Devuelve 0 si la tabla no existe todavia.
|
||||
int chat_mutations_counter();
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// Logging con tags
|
||||
//
|
||||
// Todas las trazas del subsistema chat van a `<app_dir>/chat.log` ademas de
|
||||
// stderr. Cada linea tiene formato:
|
||||
//
|
||||
// 2026-05-01T18:35:50.853Z [chat:detect] mensaje
|
||||
//
|
||||
// Tags usados (grep amigable):
|
||||
// detect deteccion de claude/wsl al arrancar
|
||||
// env env vars seteadas para el subprocess
|
||||
// spawn argv completo + cwd al lanzar el subprocess
|
||||
// io operaciones sobre los pipes (lectura/escritura/EOF)
|
||||
// parse eventos JSON parseados desde stream-json
|
||||
// tools tool_use detectados, comandos Bash invocados
|
||||
// mut cambios detectados via agent_mutations.counter
|
||||
// error fallos y exit codes
|
||||
// ----------------------------------------------------------------------------
|
||||
void chat_log(const char* tag, const char* fmt, ...);
|
||||
|
||||
// Devuelve el path absoluto del fichero de log (vacio si no inicializado).
|
||||
const char* chat_log_path();
|
||||
|
||||
} // namespace app_agent
|
||||
Reference in New Issue
Block a user