Now About Social Code
aboutsummaryrefslogtreecommitdiff
path: root/src/relay
diff options
context:
space:
mode:
authorLucas Fryzek <lucas.fryzek@fryzekconcepts.com>2025-01-15 17:26:17 +0000
committerLucas Fryzek <lucas.fryzek@fryzekconcepts.com>2025-01-15 17:26:17 +0000
commit1310a03148eac23db565ca0c6bbd5ae490024637 (patch)
treea65e618360c8f7233fa994da593579c06178e0f0 /src/relay
parentce0bada559e24501c31707dddd90f9d9b927a568 (diff)
network: Improve disconnect handling
Make sure disconnecting closes the SSH tunnel connection. Also add keep alive ping to check if connection to server is still there and time out if the keep alive ping does not respond.
Diffstat (limited to 'src/relay')
-rw-r--r--src/relay/network.py31
1 files changed, 23 insertions, 8 deletions
diff --git a/src/relay/network.py b/src/relay/network.py
index b27edaa..18d2920 100644
--- a/src/relay/network.py
+++ b/src/relay/network.py
@@ -121,11 +121,6 @@ class Network(GObject.GObject):
self._socketclient = Gio.SocketClient.new()
self._socket = None
- # TODO figure out how to deal with these signals
- #self._socket.connected.self._socket_connected)
- #self._socket.readyRead.connect(self._socket_read)
- #self._socket.disconnected.connect(self._socket_disconnected)
-
def _init_connection(self):
self.status = STATUS_DISCONNECTED
self._hostname = None
@@ -138,6 +133,7 @@ class Network(GObject.GObject):
self._pwd_hash_algo = None
self._pwd_hash_iter = 0
self._server_nonce = None
+ self.ssh_tunnel = None
def set_status(self, status):
"""Set current status."""
@@ -208,6 +204,12 @@ class Network(GObject.GObject):
self.send_to_weechat(_PROTO_HANDSHAKE)
self._handshake_timer = GLib.timeout_add(2000, self.handshake_timer_expired)
+ def keep_alive(self):
+ if self.is_connected():
+ self.send_to_weechat("ping keep_alive\n")
+ GLib.timeout_add(30*1000, self.keep_alive)
+ return False
+
def _socket_read(self, source_object, res, *user_data):
"""Slot: data available on socket."""
try:
@@ -230,6 +232,7 @@ class Network(GObject.GObject):
self._buffer = self._buffer[0:length]
self.emit("message_from_weechat", GLib.Bytes(self._buffer))
if not self.is_connected():
+ self.disconnect()
return
self._buffer.clear()
if remainder:
@@ -238,10 +241,12 @@ class Network(GObject.GObject):
self.input.read_bytes_async(
4096, 0, self.cancel_network_reads, self._socket_read)
- def _socket_disconnected(self):
+ def disconnect(self):
"""Slot: socket disconnected."""
- if self._handshake_timer:
- self._handshake_timer.stop()
+ if self._handshake_timer is not None:
+ GLib.source_remove(self._handshake_timer)
+ if self.ssh_tunnel is not None:
+ self.ssh_tunnel.stop(force=True)
self._init_connection()
self.set_status(STATUS_DISCONNECTED)
@@ -291,6 +296,9 @@ class Network(GObject.GObject):
Gio.NetworkAddress.new(self._hostname, self._port),
None,
self._connected_func, None)
+
+ # TODO probably make the timeout configurable
+ self._socketclient.set_timeout(60)
self.set_status(STATUS_CONNECTING)
def _connected_func(self, source_object, res, *user_data):
@@ -324,19 +332,25 @@ class Network(GObject.GObject):
self.set_status(STATUS_DISCONNECTED)
def handle_network_error(self, err):
+ print("net err")
if err.matches(Gio.io_error_quark(), Gio.IOErrorEnum.CANCELLED):
print("Connection has been canceled by user.")
+ self.disconnect()
return
elif err.matches(Gio.tls_error_quark(), Gio.TlsError.EOF):
print("Server has closed the connection.")
+ self.disconnect()
return
elif err.matches(Gio.io_error_quark(), Gio.IOErrorEnum.BROKEN_PIPE):
print("Broken pipe, connection lost.")
+ self.disconnect()
return
elif err.matches(Gio.io_error_quark(), Gio.IOErrorEnum.TIMED_OUT):
print("Connection timed out.")
+ self.disconnect()
return
else:
+ print("Unhandled net error {}".format(err))
raise
def send_to_weechat(self, message):
@@ -358,6 +372,7 @@ class Network(GObject.GObject):
self.send_to_weechat(cmd)
self.sync_weechat()
self.set_status(STATUS_CONNECTED)
+ GLib.timeout_add(30*1000, self.keep_alive)
return
# failed to initialize: disconnect
self.disconnect_weechat()