namespace SVSim.BattleNode.Bridge;
///
/// DI-injected options for the battle node. NodeServerUrl matches the prod
/// do_matching wire format: host:port/socket.io/, no scheme prefix.
/// BestHTTP's SocketManager parses it as the Socket.IO v2 endpoint URL.
///
public sealed class BattleNodeOptions
{
public string NodeServerUrl { get; set; } = "localhost:5148/socket.io/";
///
/// How long the first arriver's WS waits for a partner before disconnecting.
/// Matches the architecture spec's 60s default; override (typically lower)
/// in tests via the factory.
///
public TimeSpan WaitingRoomTimeout { get; set; } = TimeSpan.FromSeconds(60);
///
/// Cadence of the server→client alive ("Gungnir") keepalive emit. The driving timer/loop
/// (to live on ) is deferred in v1; this is its future
/// home so the interval isn't a magic literal stranded on the Gungnir body factory.
///
public TimeSpan AliveEmitInterval { get; set; } = TimeSpan.FromSeconds(5);
///
/// When true, emits per-frame
/// diagnostic logs at Information level: [sio-in] on every inbound msg/alive/hand
/// envelope (URI, pubSeq, ackId, dispatch decision, ack-sent flag, ack arg, inbound
/// watermark); [sio-out] on every outbound push (URI, pubSeq, playSeq, stock);
/// [ws-rx-text] / [ws-rx-bin] on every WS frame received at the transport
/// layer; [ws-recv-exit] / [ws-loop-exit] on read-loop termination
/// (with WebSocket state + exception type when applicable). Default false — keeps
/// production logs clean. Flip on per session for live WS debugging, PvP investigation,
/// or to reproduce the kind of softlock chased in
/// docs/audits/battle-node-sio-events-2026-06-02.md.
///
public bool DiagnosticLogging { get; set; } = false;
}