From 2b07510f24041829e034d396d67149ead31eba52 Mon Sep 17 00:00:00 2001 From: vince-fugnitto Date: Fri, 26 Mar 2021 12:37:00 -0400 Subject: [PATCH] vsx-registry: update api-compatibility handling The following commit updates the logic present in `@theia/vsx-registry` which is used to determine API-compatible extensions. The changes update the previous assumption that vscode-builtin extensions could not be downloaded through the extensions-view. The updated logic behaves in the following way: - builtins bundled with the application are excluded from fetching their compatible version. - builtins installed through the extensions-view are checked for their latest compatible version. Signed-off-by: vince-fugnitto --- .../src/browser/vsx-extensions-model.ts | 14 +++++++++++++- .../vsx-registry/src/common/vsx-registry-api.ts | 10 +--------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/packages/vsx-registry/src/browser/vsx-extensions-model.ts b/packages/vsx-registry/src/browser/vsx-extensions-model.ts index b011688b4849b..3dd4d69b8aa0e 100644 --- a/packages/vsx-registry/src/browser/vsx-extensions-model.ts +++ b/packages/vsx-registry/src/browser/vsx-extensions-model.ts @@ -217,6 +217,10 @@ export class VSXExtensionsModel { protected async refresh(id: string): Promise { try { + let extension = this.getExtension(id); + if (!this.shouldRefresh(extension)) { + return extension; + } const data = await this.api.getLatestCompatibleExtensionVersion(id); if (!data) { return; @@ -224,7 +228,7 @@ export class VSXExtensionsModel { if (data.error) { return this.onDidFailRefresh(id, data.error); } - const extension = this.setExtension(id); + extension = this.setExtension(id); extension.update(Object.assign(data, { publisher: data.namespace, downloadUrl: data.files.download, @@ -239,6 +243,14 @@ export class VSXExtensionsModel { } } + /** + * Determines if the given extension should be refreshed. + * @param extension the extension to refresh. + */ + protected shouldRefresh(extension?: VSXExtension): boolean { + return extension?.builtin !== true; + } + // eslint-disable-next-line @typescript-eslint/no-explicit-any protected onDidFailRefresh(id: string, error: any): VSXExtension | undefined { const cached = this.getExtension(id); diff --git a/packages/vsx-registry/src/common/vsx-registry-api.ts b/packages/vsx-registry/src/common/vsx-registry-api.ts index 28ba7878b9992..7158d5e5df880 100644 --- a/packages/vsx-registry/src/common/vsx-registry-api.ts +++ b/packages/vsx-registry/src/common/vsx-registry-api.ts @@ -41,11 +41,6 @@ export namespace VSXResponseError { } } -/** - * Namespace reserved for vscode builtin extensions. - */ -const VSCODE_NAMESPACE = 'vscode'; - @injectable() export class VSXRegistryAPI { @@ -145,10 +140,7 @@ export class VSXRegistryAPI { const extensions = await this.getAllVersions(id); for (let i = 0; i < extensions.length; i++) { const extension: VSXExtensionRaw = extensions[i]; - // Skip vscode builtin extensions. - if (extension.namespace === VSCODE_NAMESPACE) { - return extension; - } else if (extension.engines && this.isEngineSupported(extension.engines.vscode)) { + if (extension.engines && this.isEngineSupported(extension.engines.vscode)) { return extension; } }