From 3951426c1218db1c3a4e2a7f7cdf1e9764b1b280 Mon Sep 17 00:00:00 2001 From: Adrien FIGARD Date: Tue, 6 Aug 2024 10:55:04 +0200 Subject: [PATCH 1/3] :bug: More precise mapping resolving --- patches/@graphql-tools+executor+1.2.1.patch | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/patches/@graphql-tools+executor+1.2.1.patch b/patches/@graphql-tools+executor+1.2.1.patch index 5daa021..2f43831 100644 --- a/patches/@graphql-tools+executor+1.2.1.patch +++ b/patches/@graphql-tools+executor+1.2.1.patch @@ -1,7 +1,7 @@ diff --git a/node_modules/@graphql-tools/executor/cjs/execution/execute.js b/node_modules/@graphql-tools/executor/cjs/execution/execute.js old mode 100644 new mode 100755 -index 791e3df..ae399d9 +index 791e3df..0333b51 --- a/node_modules/@graphql-tools/executor/cjs/execution/execute.js +++ b/node_modules/@graphql-tools/executor/cjs/execution/execute.js @@ -628,8 +628,13 @@ function completeAbstractValue(exeContext, returnType, fieldNodes, info, path, r @@ -19,7 +19,7 @@ index 791e3df..ae399d9 } // releases before 16.0.0 supported returning `GraphQLObjectType` from `resolveType` // TODO: remove in 17.0.0 release -@@ -640,6 +645,17 @@ function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNo +@@ -640,6 +645,18 @@ function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNo throw (0, utils_1.createGraphQLError)(`Abstract type "${returnType.name}" must resolve to an Object type at runtime for field "${info.parentType.name}.${info.fieldName}" with ` + `value ${(0, utils_1.inspect)(result)}, received "${(0, utils_1.inspect)(runtimeTypeName)}".`); } @@ -29,7 +29,8 @@ index 791e3df..ae399d9 + .find(a => a.name.value === "mapping").value.value) + Object.keys(mappedTypes).forEach((type) => { + // For each key in the mapping object, check if the runtimeTypeName includes the key -+ if (runtimeTypeName.includes(type)) { ++ const runtimeTypeNameWithoutVersion = runtimeTypeName.substring(0, runtimeTypeName.length-3) ++ if (runtimeTypeNameWithoutVersion === type) { + // Replace the key with its corresponding mapped type in the runtimeTypeName + runtimeTypeName = runtimeTypeName.replace(type, mappedTypes[type]) + } From 3cb76de16ef2acd8a0eb8cf5f15499ad2a58f52c Mon Sep 17 00:00:00 2001 From: Adrien FIGARD Date: Tue, 6 Aug 2024 11:31:43 +0200 Subject: [PATCH 2/3] :bug: Fix bug when types are not versioned --- patches/@graphql-tools+executor+1.2.1.patch | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/patches/@graphql-tools+executor+1.2.1.patch b/patches/@graphql-tools+executor+1.2.1.patch index 2f43831..ac833db 100644 --- a/patches/@graphql-tools+executor+1.2.1.patch +++ b/patches/@graphql-tools+executor+1.2.1.patch @@ -1,7 +1,7 @@ diff --git a/node_modules/@graphql-tools/executor/cjs/execution/execute.js b/node_modules/@graphql-tools/executor/cjs/execution/execute.js old mode 100644 new mode 100755 -index 791e3df..0333b51 +index 791e3df..1e8e7fb --- a/node_modules/@graphql-tools/executor/cjs/execution/execute.js +++ b/node_modules/@graphql-tools/executor/cjs/execution/execute.js @@ -628,8 +628,13 @@ function completeAbstractValue(exeContext, returnType, fieldNodes, info, path, r @@ -19,7 +19,7 @@ index 791e3df..0333b51 } // releases before 16.0.0 supported returning `GraphQLObjectType` from `resolveType` // TODO: remove in 17.0.0 release -@@ -640,6 +645,18 @@ function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNo +@@ -640,6 +645,25 @@ function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNo throw (0, utils_1.createGraphQLError)(`Abstract type "${returnType.name}" must resolve to an Object type at runtime for field "${info.parentType.name}.${info.fieldName}" with ` + `value ${(0, utils_1.inspect)(result)}, received "${(0, utils_1.inspect)(runtimeTypeName)}".`); } @@ -29,8 +29,15 @@ index 791e3df..0333b51 + .find(a => a.name.value === "mapping").value.value) + Object.keys(mappedTypes).forEach((type) => { + // For each key in the mapping object, check if the runtimeTypeName includes the key -+ const runtimeTypeNameWithoutVersion = runtimeTypeName.substring(0, runtimeTypeName.length-3) -+ if (runtimeTypeNameWithoutVersion === type) { ++ const splits = runtimeTypeName.split('_') ++ // Remove the version ++ splits.pop() ++ let joinedSplits = f.join('_') ++ // If the runtimeTypeName is not versioned ++ if (joinedSplits === "") { ++ joinedSplits = runtimeTypeName ++ } ++ if (joinedSplits === type) { + // Replace the key with its corresponding mapped type in the runtimeTypeName + runtimeTypeName = runtimeTypeName.replace(type, mappedTypes[type]) + } From 44ca56a85cbba1c1bbaaa326cb7490b629eb6584 Mon Sep 17 00:00:00 2001 From: Adrien FIGARD Date: Tue, 6 Aug 2024 11:38:02 +0200 Subject: [PATCH 3/3] :bug: Fix code --- patches/@graphql-tools+executor+1.2.1.patch | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/patches/@graphql-tools+executor+1.2.1.patch b/patches/@graphql-tools+executor+1.2.1.patch index ac833db..d954e31 100644 --- a/patches/@graphql-tools+executor+1.2.1.patch +++ b/patches/@graphql-tools+executor+1.2.1.patch @@ -1,7 +1,7 @@ diff --git a/node_modules/@graphql-tools/executor/cjs/execution/execute.js b/node_modules/@graphql-tools/executor/cjs/execution/execute.js old mode 100644 new mode 100755 -index 791e3df..1e8e7fb +index 791e3df..0210559 --- a/node_modules/@graphql-tools/executor/cjs/execution/execute.js +++ b/node_modules/@graphql-tools/executor/cjs/execution/execute.js @@ -628,8 +628,13 @@ function completeAbstractValue(exeContext, returnType, fieldNodes, info, path, r @@ -32,7 +32,7 @@ index 791e3df..1e8e7fb + const splits = runtimeTypeName.split('_') + // Remove the version + splits.pop() -+ let joinedSplits = f.join('_') ++ let joinedSplits = splits.join('_') + // If the runtimeTypeName is not versioned + if (joinedSplits === "") { + joinedSplits = runtimeTypeName