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:
parent
c0eb4c6dea
commit
9d181ab6ab
@ -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;
|
||||||
|
|||||||
@ -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);
|
||||||
};
|
};
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user