1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00

chore: Move stopping extensions to own runnable

Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
Sebastian Malton 2023-04-05 10:07:22 -04:00
parent c0eb4c6dea
commit 9d181ab6ab
2 changed files with 9 additions and 10 deletions

View File

@ -5,21 +5,23 @@
import { getInjectable } from "@ogre-tools/injectable"; import { getInjectable } from "@ogre-tools/injectable";
import extensionInjectable from "../../../../extensions/extension-loader/extension/extension.injectable"; import extensionInjectable from "../../../../extensions/extension-loader/extension/extension.injectable";
import extensionsInjectable from "../../../../extensions/extensions.injectable"; import extensionsInjectable from "../../../../extensions/extensions.injectable";
import { onQuitOfBackEndInjectionToken } from "../../../../main/start-main-application/runnable-tokens/phases";
const stopAllExtensionsInjectable = getInjectable({ const stopAllExtensionsOnQuitInjectable = getInjectable({
id: "stop-all-extensions", id: "stop-all-extensions",
instantiate: (di) => { instantiate: (di) => ({
run: async () => {
const extensionInstances = di.inject(extensionsInjectable); const extensionInstances = di.inject(extensionsInjectable);
return async () => {
for (const instance of extensionInstances.get()) { for (const instance of extensionInstances.get()) {
const extension = di.inject(extensionInjectable, instance); const extension = di.inject(extensionInjectable, instance);
await instance.disable(); await instance.disable();
extension.deregister(); extension.deregister();
} }
};
}, },
}),
injectionToken: onQuitOfBackEndInjectionToken,
}); });
export default stopAllExtensionsInjectable; export default stopAllExtensionsOnQuitInjectable;

View File

@ -8,7 +8,6 @@ import clusterManagerInjectable from "./cluster/manager.injectable";
import loggerInjectable from "../common/logger.injectable"; import loggerInjectable from "../common/logger.injectable";
import closeAllWindowsInjectable from "./start-main-application/lens-window/hide-all-windows/close-all-windows.injectable"; import closeAllWindowsInjectable from "./start-main-application/lens-window/hide-all-windows/close-all-windows.injectable";
import emitAppEventInjectable from "../common/app-event-bus/emit-event.injectable"; import emitAppEventInjectable from "../common/app-event-bus/emit-event.injectable";
import stopAllExtensionsInjectable from "../features/extensions/stopping/main/stop-all.injectable";
const stopServicesAndExitAppInjectable = getInjectable({ const stopServicesAndExitAppInjectable = getInjectable({
id: "stop-services-and-exit-app", id: "stop-services-and-exit-app",
@ -19,13 +18,11 @@ const stopServicesAndExitAppInjectable = getInjectable({
const logger = di.inject(loggerInjectable); const logger = di.inject(loggerInjectable);
const closeAllWindows = di.inject(closeAllWindowsInjectable); const closeAllWindows = di.inject(closeAllWindowsInjectable);
const emitAppEvent = di.inject(emitAppEventInjectable); const emitAppEvent = di.inject(emitAppEventInjectable);
const stopAllExtensions = di.inject(stopAllExtensionsInjectable);
return async () => { return async () => {
emitAppEvent({ name: "service", action: "close" }); emitAppEvent({ name: "service", action: "close" });
closeAllWindows(); closeAllWindows();
clusterManager.stop(); clusterManager.stop();
await stopAllExtensions();
logger.info("SERVICE:QUIT"); logger.info("SERVICE:QUIT");
setTimeout(forceAppExit, 1000); setTimeout(forceAppExit, 1000);
}; };