From 7f65dfd1b2a40ffcfae7ea4a51b1ef1ee19cc99d Mon Sep 17 00:00:00 2001 From: "Patrik J. Braun" Date: Mon, 25 Mar 2024 21:47:05 +0100 Subject: [PATCH] Check if folder exists before listing it. --- .../ExtensionConfigTemplateLoader.ts | 56 +++++++++---------- 1 file changed, 28 insertions(+), 28 deletions(-) diff --git a/src/backend/model/extension/ExtensionConfigTemplateLoader.ts b/src/backend/model/extension/ExtensionConfigTemplateLoader.ts index 643aad7d..fc989b9e 100644 --- a/src/backend/model/extension/ExtensionConfigTemplateLoader.ts +++ b/src/backend/model/extension/ExtensionConfigTemplateLoader.ts @@ -40,34 +40,36 @@ export class ExtensionConfigTemplateLoader { // already loaded if (!this.loaded) { - this.extensionList = (fs - .readdirSync(this.extensionsFolder)) - .filter((f): boolean => - fs.statSync(path.join(this.extensionsFolder, f)).isDirectory() - ); - this.extensionList.sort(); - this.extensionTemplates = []; - for (let i = 0; i < this.extensionList.length; ++i) { - const extFolder = this.extensionList[i]; - const extPath = path.join(this.extensionsFolder, extFolder); - const serverExtPath = path.join(extPath, 'server.js'); - if (!fs.existsSync(serverExtPath)) { - continue; - } + if (fs.existsSync(this.extensionsFolder)) { + this.extensionList = (fs + .readdirSync(this.extensionsFolder)) + .filter((f): boolean => + fs.statSync(path.join(this.extensionsFolder, f)).isDirectory() + ); + this.extensionList.sort(); + + for (let i = 0; i < this.extensionList.length; ++i) { + const extFolder = this.extensionList[i]; + const extPath = path.join(this.extensionsFolder, extFolder); + const serverExtPath = path.join(extPath, 'server.js'); + if (!fs.existsSync(serverExtPath)) { + continue; + } - // eslint-disable-next-line @typescript-eslint/no-var-requires - const ext = require(serverExtPath); - if (typeof ext?.initConfig === 'function') { - ext?.initConfig({ - setConfigTemplate: (template: { new(): unknown }): void => { - this.extensionTemplates.push({folder: extFolder, template: template}); - } - }); - } else { - //also create basic config extensions that do not have any - this.extensionTemplates.push({folder: extFolder}); + // eslint-disable-next-line @typescript-eslint/no-var-requires + const ext = require(serverExtPath); + if (typeof ext?.initConfig === 'function') { + ext?.initConfig({ + setConfigTemplate: (template: { new(): unknown }): void => { + this.extensionTemplates.push({folder: extFolder, template: template}); + } + }); + } else { + //also create basic config extensions that do not have any + this.extensionTemplates.push({folder: extFolder}); + } } } this.loaded = true; @@ -77,8 +79,6 @@ export class ExtensionConfigTemplateLoader { } - - private setTemplatesToConfig(config: PrivateConfigClass) { if (!this.extensionTemplates) { return; @@ -100,7 +100,7 @@ export class ExtensionConfigTemplateLoader { if (!c) { c = new ServerExtensionsEntryConfig(ext.folder); if (ext.template) { - c.configs= new ext.template() + c.configs = new ext.template(); } config.Extensions.extensions.push(c); }