Added IPC retry

This commit is contained in:
Mark Qvist 2023-11-02 18:39:42 +01:00
parent 6767a707cd
commit 6eb10b566e
1 changed files with 10 additions and 3 deletions

View File

@ -1169,14 +1169,21 @@ class SidebandCore():
self.state_db[prop] = val self.state_db[prop] = val
return True return True
else: else:
try: def set():
if self.rpc_connection == None: if self.rpc_connection == None:
self.rpc_connection = multiprocessing.connection.Client(self.rpc_addr, authkey=self.rpc_key) self.rpc_connection = multiprocessing.connection.Client(self.rpc_addr, authkey=self.rpc_key)
self.rpc_connection.send({"setstate": (prop, val)}) self.rpc_connection.send({"setstate": (prop, val)})
response = self.rpc_connection.recv() response = self.rpc_connection.recv()
return response return response
try:
set()
except Exception as e: except Exception as e:
RNS.log("Error while setting state over RPC: "+str(e), RNS.LOG_DEBUG) RNS.log("Error while setting state over RPC: "+str(e)+". Retrying once.", RNS.LOG_DEBUG)
try:
set()
except Exception as e:
RNS.log("Error on retry as well: "+str(e)+". Giving up.", RNS.LOG_DEBUG)
return False return False
def service_set_latest_telemetry(self, latest_telemetry, latest_packed_telemetry): def service_set_latest_telemetry(self, latest_telemetry, latest_packed_telemetry):