moonraker: remove stale objects from subscription tracking

This prevents moonraker from subscribing to unknown printer objects on startup.

SIgned-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Arksine 2020-10-09 19:25:42 -04:00
parent 346c3ad2a0
commit f220e1b2ee
1 changed files with 7 additions and 0 deletions

View File

@ -208,6 +208,8 @@ class Server:
# Subscribe to "webhooks" # Subscribe to "webhooks"
# Register "webhooks" subscription # Register "webhooks" subscription
if "webhooks_sub" not in self.init_list: if "webhooks_sub" not in self.init_list:
temp_subs = self.all_subscriptions
self.all_subscriptions = {}
try: try:
await self.klippy_apis.subscribe_objects({'webhooks': None}) await self.klippy_apis.subscribe_objects({'webhooks': None})
except ServerError as e: except ServerError as e:
@ -215,6 +217,7 @@ class Server:
else: else:
logging.info("Webhooks Subscribed") logging.info("Webhooks Subscribed")
self.init_list.append("webhooks_sub") self.init_list.append("webhooks_sub")
self.all_subscriptions.update(temp_subs)
# Subscribe to Gcode Output # Subscribe to Gcode Output
if "gcode_output_sub" not in self.init_list: if "gcode_output_sub" not in self.init_list:
try: try:
@ -281,6 +284,10 @@ class Server:
logging.info( logging.info(
f"Unable to retreive Klipper Object List") f"Unable to retreive Klipper Object List")
return return
# Remove stale objects from the persistent subscription dict
for name in list(self.all_subscriptions.keys()):
if name not in result:
del self.all_subscriptions[name]
req_objs = set(["virtual_sdcard", "display_status", "pause_resume"]) req_objs = set(["virtual_sdcard", "display_status", "pause_resume"])
missing_objs = req_objs - set(result) missing_objs = req_objs - set(result)
if missing_objs: if missing_objs: