daemon: filter notificaions sent to client
This commit is contained in:
parent
8fb14bb5fe
commit
50bc50d78d
|
@ -73,6 +73,7 @@ class ClientThread(util.DaemonThread):
|
||||||
self.client_pipe = util.SocketPipe(s)
|
self.client_pipe = util.SocketPipe(s)
|
||||||
self.response_queue = Queue.Queue()
|
self.response_queue = Queue.Queue()
|
||||||
self.server.add_client(self)
|
self.server.add_client(self)
|
||||||
|
self.subscriptions = set()
|
||||||
|
|
||||||
def reading_thread(self):
|
def reading_thread(self):
|
||||||
while self.is_running():
|
while self.is_running():
|
||||||
|
@ -83,9 +84,13 @@ class ClientThread(util.DaemonThread):
|
||||||
if request is None:
|
if request is None:
|
||||||
self.running = False
|
self.running = False
|
||||||
break
|
break
|
||||||
if request.get('method') == 'daemon.stop':
|
method = request.get('method')
|
||||||
|
params = request.get('params')
|
||||||
|
if method == 'daemon.stop':
|
||||||
self.server.stop()
|
self.server.stop()
|
||||||
continue
|
continue
|
||||||
|
if method[-10:] == '.subscribe':
|
||||||
|
self.subscriptions.add(repr((method, params)))
|
||||||
self.server.send_request(self, request)
|
self.server.send_request(self, request)
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
|
@ -165,7 +170,10 @@ class NetworkServer(util.DaemonThread):
|
||||||
client.response_queue.put(response)
|
client.response_queue.put(response)
|
||||||
else:
|
else:
|
||||||
# notification
|
# notification
|
||||||
|
m = response.get('method')
|
||||||
|
v = response.get('params')
|
||||||
for client in self.clients:
|
for client in self.clients:
|
||||||
|
if repr((m, v)) in client.subscriptions:
|
||||||
client.response_queue.put(response)
|
client.response_queue.put(response)
|
||||||
|
|
||||||
self.network.stop()
|
self.network.stop()
|
||||||
|
|
Loading…
Reference in New Issue