SolarFM/src/versions/solarfm-0.0.1/SolarFM/solarfm/controller/IPCServerMixin.py

65 lines
1.8 KiB
Python
Raw Normal View History

# Python imports
2021-11-28 04:03:00 +00:00
import threading, socket, time
from multiprocessing.connection import Listener, Client
# Lib imports
# Application imports
def threaded(fn):
def wrapper(*args, **kwargs):
threading.Thread(target=fn, args=args, kwargs=kwargs, daemon=True).start()
return wrapper
2022-01-20 02:14:44 +00:00
class IPCServerMixin:
@threaded
def create_ipc_server(self):
2022-01-24 16:24:55 +00:00
listener = Listener((self.ipc_address, self.ipc_port), authkey=self.ipc_authkey)
self.is_ipc_alive = True
while True:
2021-11-28 04:03:00 +00:00
conn = listener.accept()
start_time = time.time()
print(f"New Connection: {listener.last_accepted}")
while True:
msg = conn.recv()
2021-11-25 08:21:10 +00:00
if debug:
print(msg)
if "FILE|" in msg:
file = msg.split("FILE|")[1].strip()
2021-11-25 08:21:10 +00:00
if file:
2022-01-31 00:09:00 +00:00
event_system.push_gui_event([None, "handle_file_from_ipc", file])
2021-11-25 08:21:10 +00:00
conn.close()
break
if msg == 'close connection':
conn.close()
break
if msg == 'close server':
conn.close()
break
2021-11-28 04:03:00 +00:00
# NOTE: Not perfect but insures we don't lockup the connection for too long.
end_time = time.time()
2022-01-24 16:24:55 +00:00
if (end - start) > self.ipc_timeout:
2021-11-28 04:03:00 +00:00
conn.close()
listener.close()
def send_ipc_message(self, message="Empty Data..."):
try:
2022-01-24 16:24:55 +00:00
conn = Client((self.ipc_address, self.ipc_port), authkey=self.ipc_authkey)
conn.send(message)
conn.send('close connection')
except Exception as e:
print(repr(e))