From d2856135a57d85ad8ed9985436e7bbf4ffc2b111 Mon Sep 17 00:00:00 2001 From: fisehara Date: Wed, 26 Apr 2023 12:59:29 +0200 Subject: [PATCH] Fix deepFreeze Actually deep freezing the `constrainedAbstractSqlModel` Change-type: patch Signed-off-by: Harald Fischer Signed-off-by: fisehara --- src/sbvr-api/permissions.ts | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/sbvr-api/permissions.ts b/src/sbvr-api/permissions.ts index ab58a8a55..b84c4275c 100644 --- a/src/sbvr-api/permissions.ts +++ b/src/sbvr-api/permissions.ts @@ -714,20 +714,20 @@ const onceGetter = ( }); }; -const deepFreezeExceptDefinition = (obj: AnyObject) => { - Object.freeze(obj); - +const deepFreeze = (obj: AnyObject) => { for (const prop of Object.getOwnPropertyNames(obj)) { - // We skip the definition because we know it's a property we've defined that will throw an error in some cases + const value = obj[prop]; if ( - prop !== 'definition' && - obj.hasOwnProperty(prop) && - obj[prop] !== null && - !['object', 'function'].includes(typeof obj[prop]) + // `synonyms` is changed later on in the constrainedAbstractSqlModel.symbols get proxy + // `tables` is changed later on in the constrainedAbstractSqlModel.tables get proxy + !['synonyms', 'tables'].includes(prop) && + value !== null && + (typeof value === 'object' || typeof value === 'function') ) { - deepFreezeExceptDefinition(obj); + deepFreeze(value); } } + Object.freeze(obj); }; const createBypassDefinition = (definition: Definition) => @@ -1095,7 +1095,7 @@ const getBoundConstrainedMemoizer = memoizeWeak( }, }, ); - deepFreezeExceptDefinition(constrainedAbstractSqlModel); + deepFreeze(constrainedAbstractSqlModel); return constrainedAbstractSqlModel; }, {