This code implements a fault-tolerant proxy client for connecting to Chronik blockchain indexers. Key features include:
Automatic failover between multiple Chronik endpoints
Conversion between HTTP/HTTPS URLs and their WebSocket equivalents
HTTP request handling (GET/POST) with error management
WebSocket connection establishment and validation
Subscription management for scripts, Lokad IDs, tokens, and blocks
Automatic reconnection with retention of previous subscriptions
Connection timeouts and status tracking
Error handling for server indexing states and connection failures
The client maintains state about working endpoints and can cycle through multiple servers when the current one becomes unavailable.