From 84d753fa259a25df3962aaac48ce881052e7d682 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=CE=A3rebe=20-=20Romain=20GERARD?= Date: Mon, 4 Mar 2024 17:06:00 +0100 Subject: [PATCH] fix: auto-reconnect to server after conect failure instead of exiting --- src/tunnel/client.rs | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/src/tunnel/client.rs b/src/tunnel/client.rs index cf03256..c26bcab 100644 --- a/src/tunnel/client.rs +++ b/src/tunnel/client.rs @@ -109,16 +109,30 @@ where // Correctly configure tunnel cfg let (ws_rx, ws_tx, response) = match client_cfg.remote_addr.scheme() { TransportScheme::Ws | TransportScheme::Wss => { - tunnel::transport::websocket::connect(request_id, &client_cfg, &remote_addr) + match tunnel::transport::websocket::connect(request_id, &client_cfg, &remote_addr) .instrument(span.clone()) .await - .map(|(r, w, response)| (TunnelReader::Websocket(r), TunnelWriter::Websocket(w), response))? + { + Ok((r, w, response)) => (TunnelReader::Websocket(r), TunnelWriter::Websocket(w), response), + Err(err) => { + error!("Retrying in 1sec, cannot connect to remote server: {:?}", err); + tokio::time::sleep(tokio::time::Duration::from_secs(1)).await; + continue; + } + } } TransportScheme::Http | TransportScheme::Https => { - tunnel::transport::http2::connect(request_id, &client_cfg, &remote_addr) + match tunnel::transport::http2::connect(request_id, &client_cfg, &remote_addr) .instrument(span.clone()) .await - .map(|(r, w, response)| (TunnelReader::Http2(r), TunnelWriter::Http2(w), response))? + { + Ok((r, w, response)) => (TunnelReader::Http2(r), TunnelWriter::Http2(w), response), + Err(err) => { + error!("Retrying in 1sec, cannot connect to remote server: {:?}", err); + tokio::time::sleep(tokio::time::Duration::from_secs(1)).await; + continue; + } + } } };