mirror of
https://github.com/GNS3/gns3-server
synced 2024-11-30 20:28:08 +00:00
Fix issue with asyncio.Queue which is not thread safe.
This commit is contained in:
parent
e83e12b51a
commit
31a2cb998d
@ -15,7 +15,7 @@
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
|
||||
import asyncio
|
||||
from contextlib import contextmanager
|
||||
from gns3server.utils.notification_queue import NotificationQueue
|
||||
|
||||
@ -28,6 +28,7 @@ class NotificationManager:
|
||||
|
||||
def __init__(self):
|
||||
self._listeners = set()
|
||||
self._loop = asyncio.get_event_loop()
|
||||
|
||||
@contextmanager
|
||||
def queue(self):
|
||||
@ -54,7 +55,7 @@ class NotificationManager:
|
||||
"""
|
||||
|
||||
for listener in self._listeners:
|
||||
listener.put_nowait((action, event, kwargs))
|
||||
self._loop.call_soon_threadsafe(listener.put_nowait, (action, event, kwargs))
|
||||
|
||||
@staticmethod
|
||||
def reset():
|
||||
|
@ -15,7 +15,7 @@
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
import os
|
||||
import asyncio
|
||||
from contextlib import contextmanager
|
||||
|
||||
from gns3server.utils.notification_queue import NotificationQueue
|
||||
@ -32,6 +32,7 @@ class Notification:
|
||||
self._controller = controller
|
||||
self._project_listeners = {}
|
||||
self._controller_listeners = set()
|
||||
self._loop = asyncio.get_event_loop()
|
||||
|
||||
@contextmanager
|
||||
def project_queue(self, project_id):
|
||||
@ -73,7 +74,7 @@ class Notification:
|
||||
"""
|
||||
|
||||
for controller_listener in self._controller_listeners:
|
||||
controller_listener.put_nowait((action, event, {}))
|
||||
self._loop.call_soon_threadsafe(controller_listener.put_nowait, (action, event, {}))
|
||||
|
||||
def project_has_listeners(self, project_id):
|
||||
"""
|
||||
@ -134,7 +135,7 @@ class Notification:
|
||||
except KeyError:
|
||||
return
|
||||
for listener in project_listeners:
|
||||
listener.put_nowait((action, event, {}))
|
||||
self._loop.call_soon_threadsafe(listener.put_nowait, (action, event, {}))
|
||||
|
||||
def _send_event_to_all_projects(self, action, event):
|
||||
"""
|
||||
@ -146,4 +147,4 @@ class Notification:
|
||||
"""
|
||||
for project_listeners in self._project_listeners.values():
|
||||
for listener in project_listeners:
|
||||
listener.put_nowait((action, event, {}))
|
||||
self._loop.call_soon_threadsafe(listener.put_nowait, (action, event, {}))
|
||||
|
Loading…
Reference in New Issue
Block a user