mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Add bundle extension updater classes
Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>
This commit is contained in:
parent
de75d9d680
commit
b6d06c8ca3
@ -21,6 +21,7 @@ import type { LensRendererExtension } from "../lens-renderer-extension";
|
|||||||
import { NpmJsVersionChecker } from "../npmjs-latest-version.checker";
|
import { NpmJsVersionChecker } from "../npmjs-latest-version.checker";
|
||||||
import * as registries from "../registries";
|
import * as registries from "../registries";
|
||||||
import type { LensExtensionState } from "../extensions-store/extensions-store";
|
import type { LensExtensionState } from "../extensions-store/extensions-store";
|
||||||
|
import { BundledVersionChecker } from "../bundled-latest-version-checker";
|
||||||
|
|
||||||
const logModule = "[EXTENSIONS-LOADER]";
|
const logModule = "[EXTENSIONS-LOADER]";
|
||||||
|
|
||||||
@ -65,6 +66,7 @@ export class ExtensionLoader {
|
|||||||
private extensionUpdateSources = {
|
private extensionUpdateSources = {
|
||||||
github: new GitHubVersionChecker(),
|
github: new GitHubVersionChecker(),
|
||||||
npmJs: new NpmJsVersionChecker(),
|
npmJs: new NpmJsVersionChecker(),
|
||||||
|
bundled: new BundledVersionChecker(),
|
||||||
};
|
};
|
||||||
|
|
||||||
@observable isLoaded = false;
|
@observable isLoaded = false;
|
||||||
@ -112,6 +114,10 @@ export class ExtensionLoader {
|
|||||||
return extensions;
|
return extensions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@computed get bundledExtensions(): InstalledExtension[] {
|
||||||
|
return [...this.extensions.values()].filter(extension => extension.isBundled)
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the extension instance by its manifest name
|
* Get the extension instance by its manifest name
|
||||||
* @param name The name of the extension
|
* @param name The name of the extension
|
||||||
@ -282,9 +288,7 @@ export class ExtensionLoader {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!extension.isBundled) {
|
this.checkForExtensionUpdate(extension);
|
||||||
this.checkForExtensionUpdate(extension);
|
|
||||||
}
|
|
||||||
|
|
||||||
return removeItems;
|
return removeItems;
|
||||||
});
|
});
|
||||||
|
|||||||
@ -0,0 +1,21 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { getInjectable, lifecycleEnum } from "@ogre-tools/injectable";
|
||||||
|
import installFromInputInjectable from "../../renderer/components/+extensions/install-from-input/install-from-input.injectable";
|
||||||
|
import extensionLoaderInjectable from "../extension-loader/extension-loader.injectable";
|
||||||
|
import { BundledExtensionsUpdater } from "./bundled-extensions-updater";
|
||||||
|
|
||||||
|
const bundledExtensionsUpdaterInjectable = getInjectable({
|
||||||
|
instantiate: (di) =>
|
||||||
|
new BundledExtensionsUpdater({
|
||||||
|
installFromInput: di.inject(installFromInputInjectable),
|
||||||
|
extensions: di.inject(extensionLoaderInjectable).bundledExtensions
|
||||||
|
}),
|
||||||
|
|
||||||
|
lifecycle: lifecycleEnum.singleton,
|
||||||
|
});
|
||||||
|
|
||||||
|
export default bundledExtensionsUpdaterInjectable;
|
||||||
@ -0,0 +1,34 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { BundledExtensionsLoaded, ipcRendererOn } from "../../common/ipc"
|
||||||
|
import { logger } from "../common-api";
|
||||||
|
import type { InstalledExtension } from "../extension-discovery/extension-discovery";
|
||||||
|
import { ExtensionUpdater, UpdaterDependencies } from "./extension-updater";
|
||||||
|
|
||||||
|
interface Dependencies extends UpdaterDependencies {
|
||||||
|
extensions: InstalledExtension[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export class BundledExtensionsUpdater extends ExtensionUpdater {
|
||||||
|
constructor(protected dependencies: Dependencies) {
|
||||||
|
super(dependencies);
|
||||||
|
}
|
||||||
|
|
||||||
|
init() {
|
||||||
|
ipcRendererOn(BundledExtensionsLoaded, (event) => {
|
||||||
|
this.updateAll();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private async updateAll() {
|
||||||
|
logger.info("[EXTENSIONS-UPDATER]: Bundled extensions update started.");
|
||||||
|
|
||||||
|
const updates = this.dependencies.extensions.map(this.update);
|
||||||
|
await Promise.allSettled(updates);
|
||||||
|
|
||||||
|
logger.info("[EXTENSIONS-UPDATER]: Bundled extensions update finished.");
|
||||||
|
}
|
||||||
|
}
|
||||||
28
src/extensions/extension-updater/extension-updater.ts
Normal file
28
src/extensions/extension-updater/extension-updater.ts
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import type { InstalledExtension } from "../extension-discovery/extension-discovery"
|
||||||
|
|
||||||
|
export interface UpdaterDependencies {
|
||||||
|
installFromInput: (input: string) => Promise<void>;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class ExtensionUpdater {
|
||||||
|
constructor(protected dependencies : UpdaterDependencies) {
|
||||||
|
}
|
||||||
|
|
||||||
|
async update({ availableUpdate, manifest }: InstalledExtension): Promise<void> {
|
||||||
|
return new Promise(resolve => {
|
||||||
|
if (availableUpdate) {
|
||||||
|
console.info(`[EXTENSIONS-UPDATER]: Trying to update ${manifest.name} extension`);
|
||||||
|
|
||||||
|
resolve();
|
||||||
|
// TODO: actual install
|
||||||
|
// this.dependencies.installFromInput(availableUpdate.input);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -9,6 +9,7 @@ import ipcRendererInjectable from "../../../app-paths/get-value-from-registered-
|
|||||||
import bindProtocolAddRouteHandlersInjectable from "../../../protocol-handler/bind-protocol-add-route-handlers/bind-protocol-add-route-handlers.injectable";
|
import bindProtocolAddRouteHandlersInjectable from "../../../protocol-handler/bind-protocol-add-route-handlers/bind-protocol-add-route-handlers.injectable";
|
||||||
import lensProtocolRouterRendererInjectable from "../../../protocol-handler/lens-protocol-router-renderer/lens-protocol-router-renderer.injectable";
|
import lensProtocolRouterRendererInjectable from "../../../protocol-handler/lens-protocol-router-renderer/lens-protocol-router-renderer.injectable";
|
||||||
import catalogEntityRegistryInjectable from "../../../api/catalog-entity-registry/catalog-entity-registry.injectable";
|
import catalogEntityRegistryInjectable from "../../../api/catalog-entity-registry/catalog-entity-registry.injectable";
|
||||||
|
import bundledExtensionsUpdaterInjectable from "../../../../extensions/extension-updater/bundled-extensions-updater.injectable";
|
||||||
|
|
||||||
const initRootFrameInjectable = getInjectable({
|
const initRootFrameInjectable = getInjectable({
|
||||||
instantiate: (di) => {
|
instantiate: (di) => {
|
||||||
@ -28,6 +29,8 @@ const initRootFrameInjectable = getInjectable({
|
|||||||
),
|
),
|
||||||
|
|
||||||
catalogEntityRegistry: di.inject(catalogEntityRegistryInjectable),
|
catalogEntityRegistry: di.inject(catalogEntityRegistryInjectable),
|
||||||
|
|
||||||
|
bundledExtensionsUpdater: di.inject(bundledExtensionsUpdaterInjectable)
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
@ -9,6 +9,7 @@ import logger from "../../../../common/logger";
|
|||||||
import { unmountComponentAtNode } from "react-dom";
|
import { unmountComponentAtNode } from "react-dom";
|
||||||
import type { ExtensionLoading } from "../../../../extensions/extension-loader";
|
import type { ExtensionLoading } from "../../../../extensions/extension-loader";
|
||||||
import type { CatalogEntityRegistry } from "../../../api/catalog-entity-registry";
|
import type { CatalogEntityRegistry } from "../../../api/catalog-entity-registry";
|
||||||
|
import type { BundledExtensionsUpdater } from "../../../../extensions/extension-updater/bundled-extensions-updater";
|
||||||
|
|
||||||
interface Dependencies {
|
interface Dependencies {
|
||||||
loadExtensions: () => Promise<ExtensionLoading[]>;
|
loadExtensions: () => Promise<ExtensionLoading[]>;
|
||||||
@ -20,6 +21,8 @@ interface Dependencies {
|
|||||||
bindProtocolAddRouteHandlers: () => void;
|
bindProtocolAddRouteHandlers: () => void;
|
||||||
lensProtocolRouterRenderer: { init: () => void };
|
lensProtocolRouterRenderer: { init: () => void };
|
||||||
catalogEntityRegistry: CatalogEntityRegistry;
|
catalogEntityRegistry: CatalogEntityRegistry;
|
||||||
|
|
||||||
|
bundledExtensionsUpdater: BundledExtensionsUpdater;
|
||||||
}
|
}
|
||||||
|
|
||||||
const logPrefix = "[ROOT-FRAME]:";
|
const logPrefix = "[ROOT-FRAME]:";
|
||||||
@ -30,11 +33,12 @@ export const initRootFrame =
|
|||||||
bindProtocolAddRouteHandlers,
|
bindProtocolAddRouteHandlers,
|
||||||
lensProtocolRouterRenderer,
|
lensProtocolRouterRenderer,
|
||||||
ipcRenderer,
|
ipcRenderer,
|
||||||
|
|
||||||
catalogEntityRegistry,
|
catalogEntityRegistry,
|
||||||
|
bundledExtensionsUpdater,
|
||||||
}: Dependencies) =>
|
}: Dependencies) =>
|
||||||
async (rootElem: HTMLElement) => {
|
async (rootElem: HTMLElement) => {
|
||||||
catalogEntityRegistry.init();
|
catalogEntityRegistry.init();
|
||||||
|
bundledExtensionsUpdater.init();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// maximum time to let bundled extensions finish loading
|
// maximum time to let bundled extensions finish loading
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user