From 42d7a2b1dd765630d33811ea85a13298178dab9b Mon Sep 17 00:00:00 2001 From: Mike Donnalley Date: Thu, 20 Jun 2024 09:54:28 -0600 Subject: [PATCH] chore: simplify solution --- src/config/config.ts | 37 +++++-------------------------------- 1 file changed, 5 insertions(+), 32 deletions(-) diff --git a/src/config/config.ts b/src/config/config.ts index 5b91a66bd..4cdbcce38 100644 --- a/src/config/config.ts +++ b/src/config/config.ts @@ -420,16 +420,6 @@ export class Config extends ConfigFile { return keyBy(Config.allowedProperties, 'key'); } - private static findProperty(key: string): ConfigPropertyMeta { - const property = Config.allowedProperties.find((allowedProp) => allowedProp.key === key); - - if (!property) { - throw messages.createError('unknownConfigKey', [key]); - } - - return property; - } - /** * Read, assign, and return the config contents. */ @@ -503,8 +493,11 @@ export class Config extends ConfigFile { * @param value The value of the property. */ public set>(key: K, value: ConfigProperties[K]): ConfigProperties { - const property = Config.findProperty(key); + const property = Config.allowedProperties.find((allowedProp) => allowedProp.key === key); + if (!property) { + throw messages.createError('unknownConfigKey', [key]); + } if (property.deprecated && property.newKey) { // you're trying to set a deprecated key, but we'll set the new key instead void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedConfigKey', [key, property.newKey])); @@ -597,31 +590,11 @@ export class Config extends ConfigFile { this.forEach((key, value) => { if (this.getPropertyConfig(key).encrypted && isString(value)) { - if (encrypt) { - this.setEncryptedProperty(key, ensure(crypto.encrypt(value))); - } else { - this.set(key, ensure(crypto.decrypt(value))); - } + super.set(key, ensure(encrypt ? crypto.encrypt(value) : crypto.decrypt(value))); } }); } } - - /** - * Set an encrypted property without rerunning the validator. Should only be used by `cryptProperties` method. - */ - private setEncryptedProperty>(key: K, value: ConfigProperties[K]): ConfigProperties { - const property = Config.findProperty(key); - - if (property.deprecated && property.newKey) { - // you're trying to set a deprecated key, but we'll set the new key instead - void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedConfigKey', [key, property.newKey])); - return this.set(property.newKey, value); - } - - super.set(property.key, value); - return this.getContents(); - } } /**