From 587c588d69d564b6ae4c076e916e45090378daa6 Mon Sep 17 00:00:00 2001 From: Mike Donnalley Date: Wed, 8 Nov 2023 10:08:20 -0700 Subject: [PATCH] fix: only import Config if necessary --- src/hooks/init/load_config_meta.ts | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/src/hooks/init/load_config_meta.ts b/src/hooks/init/load_config_meta.ts index dd6e7202..71e1550d 100644 --- a/src/hooks/init/load_config_meta.ts +++ b/src/hooks/init/load_config_meta.ts @@ -6,8 +6,7 @@ */ import type { Hook } from '@oclif/core'; -import { Config, ConfigPropertyMeta } from '@salesforce/core'; -import { isObject, get } from '@salesforce/ts-types'; +import type { ConfigPropertyMeta } from '@salesforce/core'; import { ModuleLoader } from '@oclif/core'; const OCLIF_META_PJSON_KEY = 'configMeta'; @@ -16,11 +15,9 @@ const hook: Hook<'init'> = async ({ config, context }): Promise => { const flattenedConfigMetas = ( await Promise.all( (config.getPluginsList() || []).flatMap(async (plugin) => { - const configMetaPath = get(plugin, `pjson.oclif.${OCLIF_META_PJSON_KEY}`, null); - - if (typeof configMetaPath !== 'string') { - return; - } + const oclif = (plugin.pjson.oclif ?? {}) as { [OCLIF_META_PJSON_KEY]?: string }; + const configMetaPath = oclif[OCLIF_META_PJSON_KEY]; + if (!configMetaPath) return; const module = await ModuleLoader.load<{ default?: ConfigPropertyMeta[] }>(plugin, configMetaPath); const configMeta = module.default; @@ -33,9 +30,10 @@ const hook: Hook<'init'> = async ({ config, context }): Promise => { ) ) .flatMap((d) => d) - .filter(isObject); + .filter((d): d is ConfigPropertyMeta => !!d); if (flattenedConfigMetas.length) { + const { Config } = await import('@salesforce/core/lib/config/config.js'); Config.addAllowedProperties(flattenedConfigMetas); } return Promise.resolve();