summaryrefslogtreecommitdiff
path: root/backend/decky_loader/loader.py
diff options
context:
space:
mode:
authorAAGaming <aagaming@riseup.net>2024-06-27 01:43:01 -0400
committerAAGaming <aagaming@riseup.net>2024-06-27 01:43:01 -0400
commitd71fb7935be69ef04c3d2bbc7ae270d326345b1e (patch)
treed3ce47af7d574d2bf1f04af04efbb5a95df6d594 /backend/decky_loader/loader.py
parent107b9abb3eb3bed2e6cbcbbe4fe315c09f4a306b (diff)
downloaddecky-loader-d71fb7935be69ef04c3d2bbc7ae270d326345b1e.tar.gz
decky-loader-d71fb7935be69ef04c3d2bbc7ae270d326345b1e.zip
fix plugin uninstall dialog issuesv3.0.0-pre1aa/websockets
Diffstat (limited to 'backend/decky_loader/loader.py')
-rw-r--r--backend/decky_loader/loader.py10
1 files changed, 5 insertions, 5 deletions
diff --git a/backend/decky_loader/loader.py b/backend/decky_loader/loader.py
index 90c54211..7881e4b1 100644
--- a/backend/decky_loader/loader.py
+++ b/backend/decky_loader/loader.py
@@ -140,7 +140,7 @@ class Loader:
with open(path.join(self.plugin_path, plugin.plugin_directory, "dist/index.js"), "r", encoding="utf-8") as bundle:
return web.Response(text=bundle.read(), content_type="application/javascript")
- def import_plugin(self, file: str, plugin_directory: str, refresh: bool | None = False, batch: bool | None = False):
+ async def import_plugin(self, file: str, plugin_directory: str, refresh: bool | None = False, batch: bool | None = False):
try:
async def plugin_emitted_event(event: str, args: Any):
self.logger.debug(f"PLUGIN EMITTED EVENT: {event} with args {args}")
@@ -152,7 +152,7 @@ class Loader:
self.logger.info(f"Plugin {plugin.name} is already loaded and has requested to not be re-loaded")
return
else:
- self.plugins[plugin.name].stop()
+ await self.plugins[plugin.name].stop()
self.plugins.pop(plugin.name, None)
if plugin.passive:
self.logger.info(f"Plugin {plugin.name} is passive")
@@ -168,18 +168,18 @@ class Loader:
async def dispatch_plugin(self, name: str, version: str | None, load_type: int = PluginLoadType.ESMODULE_V1.value):
await self.ws.emit("loader/import_plugin", name, version, load_type)
- def import_plugins(self):
+ async def import_plugins(self):
self.logger.info(f"import plugins from {self.plugin_path}")
directories = [i for i in listdir(self.plugin_path) if path.isdir(path.join(self.plugin_path, i)) and path.isfile(path.join(self.plugin_path, i, "plugin.json"))]
for directory in directories:
self.logger.info(f"found plugin: {directory}")
- self.import_plugin(path.join(self.plugin_path, directory, "main.py"), directory, False, True)
+ await self.import_plugin(path.join(self.plugin_path, directory, "main.py"), directory, False, True)
async def handle_reloads(self):
while True:
args = await self.reload_queue.get()
- self.import_plugin(*args) # pyright: ignore [reportArgumentType]
+ await self.import_plugin(*args) # pyright: ignore [reportArgumentType]
async def handle_plugin_method_call_legacy(self, plugin_name: str, method_name: str, kwargs: Dict[Any, Any]):
res: Dict[Any, Any] = {}