relay-compiler 0.0.0-main-4d287de9 → 0.0.0-main-9a79039d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cli.js +23 -0
- package/index.js +19 -3
- package/linux-x64/relay +0 -0
- package/macos-x64/relay +0 -0
- package/package.json +2 -26
- package/win-x64/relay.exe +0 -0
- package/bin/RelayCompilerBin.js.flow +0 -168
- package/bin/RelayCompilerMain.js.flow +0 -513
- package/bin/__fixtures__/plugin-module.js.flow +0 -17
- package/bin/relay-compiler +0 -19066
- package/codegen/CodegenDirectory.js.flow +0 -372
- package/codegen/CodegenRunner.js.flow +0 -424
- package/codegen/CodegenTypes.js.flow +0 -28
- package/codegen/CodegenWatcher.js.flow +0 -250
- package/codegen/NormalizationCodeGenerator.js.flow +0 -565
- package/codegen/ReaderCodeGenerator.js.flow +0 -510
- package/codegen/RelayCodeGenerator.js.flow +0 -85
- package/codegen/RelayFileWriter.js.flow +0 -365
- package/codegen/SourceControl.js.flow +0 -58
- package/codegen/compileRelayArtifacts.js.flow +0 -181
- package/codegen/createPrintRequireModuleDependency.js.flow +0 -19
- package/codegen/sortObjectByKey.js.flow +0 -25
- package/codegen/writeRelayGeneratedFile.js.flow +0 -235
- package/core/ASTCache.js.flow +0 -73
- package/core/ASTConvert.js.flow +0 -230
- package/core/CompilerContext.js.flow +0 -189
- package/core/CompilerError.js.flow +0 -255
- package/core/DotGraphQLParser.js.flow +0 -37
- package/core/GraphQLCompilerProfiler.js.flow +0 -341
- package/core/GraphQLDerivedFromMetadata.js.flow +0 -36
- package/core/GraphQLWatchmanClient.js.flow +0 -109
- package/core/IR.js.flow +0 -326
- package/core/IRPrinter.js.flow +0 -472
- package/core/IRTransformer.js.flow +0 -376
- package/core/IRValidator.js.flow +0 -259
- package/core/IRVisitor.js.flow +0 -150
- package/core/JSModuleParser.js.flow +0 -24
- package/core/RelayCompilerScope.js.flow +0 -199
- package/core/RelayFindGraphQLTags.js.flow +0 -118
- package/core/RelayGraphQLEnumsGenerator.js.flow +0 -55
- package/core/RelayIRTransforms.js.flow +0 -138
- package/core/RelayParser.js.flow +0 -1731
- package/core/RelaySourceModuleParser.js.flow +0 -133
- package/core/Schema.js.flow +0 -2035
- package/core/SchemaUtils.js.flow +0 -120
- package/core/filterContextForNode.js.flow +0 -49
- package/core/getFieldDefinition.js.flow +0 -156
- package/core/getIdentifierForArgumentValue.js.flow +0 -49
- package/core/getIdentifierForSelection.js.flow +0 -68
- package/core/getLiteralArgumentValues.js.flow +0 -32
- package/core/getNormalizationOperationName.js.flow +0 -19
- package/core/inferRootArgumentDefinitions.js.flow +0 -322
- package/index.js.flow +0 -198
- package/language/RelayLanguagePluginInterface.js.flow +0 -283
- package/language/javascript/FindGraphQLTags.js.flow +0 -136
- package/language/javascript/RelayFlowBabelFactories.js.flow +0 -176
- package/language/javascript/RelayFlowGenerator.js.flow +0 -1096
- package/language/javascript/RelayFlowTypeTransformers.js.flow +0 -181
- package/language/javascript/RelayLanguagePluginJavaScript.js.flow +0 -33
- package/language/javascript/formatGeneratedModule.js.flow +0 -65
- package/lib/bin/RelayCompilerBin.js +0 -143
- package/lib/bin/RelayCompilerMain.js +0 -486
- package/lib/bin/__fixtures__/plugin-module.js +0 -16
- package/lib/codegen/CodegenDirectory.js +0 -335
- package/lib/codegen/CodegenRunner.js +0 -433
- package/lib/codegen/CodegenTypes.js +0 -11
- package/lib/codegen/CodegenWatcher.js +0 -271
- package/lib/codegen/NormalizationCodeGenerator.js +0 -487
- package/lib/codegen/ReaderCodeGenerator.js +0 -473
- package/lib/codegen/RelayCodeGenerator.js +0 -75
- package/lib/codegen/RelayFileWriter.js +0 -270
- package/lib/codegen/SourceControl.js +0 -60
- package/lib/codegen/compileRelayArtifacts.js +0 -157
- package/lib/codegen/createPrintRequireModuleDependency.js +0 -19
- package/lib/codegen/sortObjectByKey.js +0 -41
- package/lib/codegen/writeRelayGeneratedFile.js +0 -206
- package/lib/core/ASTCache.js +0 -70
- package/lib/core/ASTConvert.js +0 -198
- package/lib/core/CompilerContext.js +0 -165
- package/lib/core/CompilerError.js +0 -252
- package/lib/core/DotGraphQLParser.js +0 -40
- package/lib/core/GraphQLCompilerProfiler.js +0 -299
- package/lib/core/GraphQLDerivedFromMetadata.js +0 -31
- package/lib/core/GraphQLWatchmanClient.js +0 -150
- package/lib/core/IR.js +0 -11
- package/lib/core/IRPrinter.js +0 -388
- package/lib/core/IRTransformer.js +0 -345
- package/lib/core/IRValidator.js +0 -226
- package/lib/core/IRVisitor.js +0 -45
- package/lib/core/JSModuleParser.js +0 -18
- package/lib/core/RelayCompilerScope.js +0 -183
- package/lib/core/RelayFindGraphQLTags.js +0 -79
- package/lib/core/RelayGraphQLEnumsGenerator.js +0 -50
- package/lib/core/RelayIRTransforms.js +0 -109
- package/lib/core/RelayParser.js +0 -1381
- package/lib/core/RelaySourceModuleParser.js +0 -104
- package/lib/core/Schema.js +0 -1877
- package/lib/core/SchemaUtils.js +0 -98
- package/lib/core/filterContextForNode.js +0 -50
- package/lib/core/getFieldDefinition.js +0 -145
- package/lib/core/getIdentifierForArgumentValue.js +0 -54
- package/lib/core/getIdentifierForSelection.js +0 -49
- package/lib/core/getLiteralArgumentValues.js +0 -26
- package/lib/core/getNormalizationOperationName.js +0 -17
- package/lib/core/inferRootArgumentDefinitions.js +0 -351
- package/lib/index.js +0 -178
- package/lib/language/RelayLanguagePluginInterface.js +0 -26
- package/lib/language/javascript/FindGraphQLTags.js +0 -126
- package/lib/language/javascript/RelayFlowBabelFactories.js +0 -160
- package/lib/language/javascript/RelayFlowGenerator.js +0 -856
- package/lib/language/javascript/RelayFlowTypeTransformers.js +0 -119
- package/lib/language/javascript/RelayLanguagePluginJavaScript.js +0 -30
- package/lib/language/javascript/formatGeneratedModule.js +0 -36
- package/lib/reporters/ConsoleReporter.js +0 -61
- package/lib/reporters/MultiReporter.js +0 -45
- package/lib/reporters/Reporter.js +0 -11
- package/lib/runner/Artifacts.js +0 -323
- package/lib/runner/BufferedFilesystem.js +0 -262
- package/lib/runner/GraphQLASTNodeGroup.js +0 -256
- package/lib/runner/GraphQLASTUtils.js +0 -23
- package/lib/runner/GraphQLNodeMap.js +0 -81
- package/lib/runner/Sources.js +0 -271
- package/lib/runner/StrictMap.js +0 -134
- package/lib/runner/compileArtifacts.js +0 -39
- package/lib/runner/extractAST.js +0 -77
- package/lib/runner/getChangedNodeNames.js +0 -82
- package/lib/runner/getSchemaInstance.js +0 -30
- package/lib/runner/types.js +0 -12
- package/lib/transforms/ApplyFragmentArgumentTransform.js +0 -393
- package/lib/transforms/ClientExtensionsTransform.js +0 -221
- package/lib/transforms/ConnectionTransform.js +0 -639
- package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
- package/lib/transforms/DeferStreamTransform.js +0 -246
- package/lib/transforms/DisallowIdAsAlias.js +0 -40
- package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
- package/lib/transforms/FieldHandleTransform.js +0 -79
- package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
- package/lib/transforms/FilterDirectivesTransform.js +0 -42
- package/lib/transforms/FlattenTransform.js +0 -306
- package/lib/transforms/GenerateIDFieldTransform.js +0 -135
- package/lib/transforms/GenerateTypeNameTransform.js +0 -149
- package/lib/transforms/InlineDataFragmentTransform.js +0 -100
- package/lib/transforms/InlineFragmentsTransform.js +0 -61
- package/lib/transforms/MaskTransform.js +0 -117
- package/lib/transforms/MatchTransform.js +0 -434
- package/lib/transforms/ReactFlightComponentTransform.js +0 -158
- package/lib/transforms/RefetchableFragmentTransform.js +0 -249
- package/lib/transforms/RelayDirectiveTransform.js +0 -83
- package/lib/transforms/RequiredFieldTransform.js +0 -369
- package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
- package/lib/transforms/SkipHandleFieldTransform.js +0 -45
- package/lib/transforms/SkipRedundantNodesTransform.js +0 -261
- package/lib/transforms/SkipSplitOperationTransform.js +0 -32
- package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
- package/lib/transforms/SkipUnusedVariablesTransform.js +0 -75
- package/lib/transforms/SplitModuleImportTransform.js +0 -82
- package/lib/transforms/TestOperationTransform.js +0 -144
- package/lib/transforms/TransformUtils.js +0 -21
- package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -92
- package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
- package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
- package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
- package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
- package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
- package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
- package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
- package/lib/transforms/query-generators/index.js +0 -60
- package/lib/transforms/query-generators/utils.js +0 -92
- package/lib/util/CodeMarker.js +0 -80
- package/lib/util/DefaultHandleKey.js +0 -15
- package/lib/util/RelayCompilerCache.js +0 -97
- package/lib/util/Rollout.js +0 -40
- package/lib/util/TimeReporter.js +0 -83
- package/lib/util/areEqualArgValues.js +0 -135
- package/lib/util/argumentContainsVariables.js +0 -37
- package/lib/util/dedupeJSONStringify.js +0 -160
- package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
- package/lib/util/getDefinitionNodeHash.js +0 -22
- package/lib/util/getModuleName.js +0 -32
- package/lib/util/joinArgumentDefinitions.js +0 -67
- package/lib/util/md5.js +0 -17
- package/lib/util/murmurHash.js +0 -86
- package/lib/util/nullthrowsOSS.js +0 -23
- package/lib/util/orList.js +0 -36
- package/lib/util/partitionArray.js +0 -35
- package/relay-compiler.js +0 -17
- package/relay-compiler.min.js +0 -22
- package/reporters/ConsoleReporter.js.flow +0 -81
- package/reporters/MultiReporter.js.flow +0 -43
- package/reporters/Reporter.js.flow +0 -19
- package/runner/Artifacts.js.flow +0 -215
- package/runner/BufferedFilesystem.js.flow +0 -194
- package/runner/GraphQLASTNodeGroup.js.flow +0 -174
- package/runner/GraphQLASTUtils.js.flow +0 -26
- package/runner/GraphQLNodeMap.js.flow +0 -55
- package/runner/Sources.js.flow +0 -227
- package/runner/StrictMap.js.flow +0 -96
- package/runner/compileArtifacts.js.flow +0 -75
- package/runner/extractAST.js.flow +0 -98
- package/runner/getChangedNodeNames.js.flow +0 -48
- package/runner/getSchemaInstance.js.flow +0 -36
- package/runner/types.js.flow +0 -37
- package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -524
- package/transforms/ClientExtensionsTransform.js.flow +0 -224
- package/transforms/ConnectionTransform.js.flow +0 -850
- package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -245
- package/transforms/DeferStreamTransform.js.flow +0 -263
- package/transforms/DisallowIdAsAlias.js.flow +0 -46
- package/transforms/DisallowTypenameOnRoot.js.flow +0 -44
- package/transforms/FieldHandleTransform.js.flow +0 -77
- package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
- package/transforms/FilterDirectivesTransform.js.flow +0 -45
- package/transforms/FlattenTransform.js.flow +0 -458
- package/transforms/GenerateIDFieldTransform.js.flow +0 -151
- package/transforms/GenerateTypeNameTransform.js.flow +0 -159
- package/transforms/InlineDataFragmentTransform.js.flow +0 -123
- package/transforms/InlineFragmentsTransform.js.flow +0 -70
- package/transforms/MaskTransform.js.flow +0 -124
- package/transforms/MatchTransform.js.flow +0 -587
- package/transforms/ReactFlightComponentTransform.js.flow +0 -194
- package/transforms/RefetchableFragmentTransform.js.flow +0 -266
- package/transforms/RelayDirectiveTransform.js.flow +0 -96
- package/transforms/RequiredFieldTransform.js.flow +0 -413
- package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
- package/transforms/SkipHandleFieldTransform.js.flow +0 -44
- package/transforms/SkipRedundantNodesTransform.js.flow +0 -255
- package/transforms/SkipSplitOperationTransform.js.flow +0 -37
- package/transforms/SkipUnreachableNodeTransform.js.flow +0 -148
- package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
- package/transforms/SplitModuleImportTransform.js.flow +0 -97
- package/transforms/TestOperationTransform.js.flow +0 -142
- package/transforms/TransformUtils.js.flow +0 -26
- package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -80
- package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -126
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -111
- package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -88
- package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -188
- package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -217
- package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
- package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
- package/transforms/query-generators/index.js.flow +0 -89
- package/transforms/query-generators/utils.js.flow +0 -76
- package/util/CodeMarker.js.flow +0 -79
- package/util/DefaultHandleKey.js.flow +0 -17
- package/util/RelayCompilerCache.js.flow +0 -86
- package/util/Rollout.js.flow +0 -39
- package/util/TimeReporter.js.flow +0 -79
- package/util/areEqualArgValues.js.flow +0 -126
- package/util/argumentContainsVariables.js.flow +0 -38
- package/util/dedupeJSONStringify.js.flow +0 -152
- package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
- package/util/getDefinitionNodeHash.js.flow +0 -24
- package/util/getModuleName.js.flow +0 -39
- package/util/joinArgumentDefinitions.js.flow +0 -105
- package/util/md5.js.flow +0 -19
- package/util/murmurHash.js.flow +0 -94
- package/util/nullthrowsOSS.js.flow +0 -25
- package/util/orList.js.flow +0 -37
- package/util/partitionArray.js.flow +0 -37
@@ -1,587 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
* @flow strict-local
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
|
13
|
-
'use strict';
|
14
|
-
|
15
|
-
import type CompilerContext from '../core/CompilerContext';
|
16
|
-
import type {
|
17
|
-
FragmentSpread,
|
18
|
-
InlineFragment,
|
19
|
-
LinkedField,
|
20
|
-
Location,
|
21
|
-
ScalarField,
|
22
|
-
} from '../core/IR';
|
23
|
-
import type {TypeID} from '../core/Schema';
|
24
|
-
|
25
|
-
const {createCompilerError, createUserError} = require('../core/CompilerError');
|
26
|
-
const getLiteralArgumentValues = require('../core/getLiteralArgumentValues');
|
27
|
-
const getNormalizationOperationName = require('../core/getNormalizationOperationName');
|
28
|
-
const IRTransformer = require('../core/IRTransformer');
|
29
|
-
const {getModuleComponentKey, getModuleOperationKey} = require('relay-runtime');
|
30
|
-
|
31
|
-
const SUPPORTED_ARGUMENT_NAME = 'supported';
|
32
|
-
|
33
|
-
const JS_FIELD_TYPE = 'JSDependency';
|
34
|
-
const JS_FIELD_MODULE_ARG = 'module';
|
35
|
-
const JS_FIELD_ID_ARG = 'id';
|
36
|
-
const JS_FIELD_NAME = 'js';
|
37
|
-
|
38
|
-
const SCHEMA_EXTENSION = `
|
39
|
-
directive @match(key: String) on FIELD
|
40
|
-
|
41
|
-
directive @module(
|
42
|
-
name: String!
|
43
|
-
) on FRAGMENT_SPREAD
|
44
|
-
`;
|
45
|
-
|
46
|
-
type State = {|
|
47
|
-
+documentName: string,
|
48
|
-
+parentType: TypeID,
|
49
|
-
+path: Array<LinkedField>,
|
50
|
-
+moduleKey: ?string,
|
51
|
-
+matchesForPath: Map<
|
52
|
-
string,
|
53
|
-
{|
|
54
|
-
+key: string,
|
55
|
-
+location: Location,
|
56
|
-
+types: Map<
|
57
|
-
string,
|
58
|
-
{|+location: Location, +fragment: string, +module: string|},
|
59
|
-
>,
|
60
|
-
|},
|
61
|
-
>,
|
62
|
-
|};
|
63
|
-
|
64
|
-
/**
|
65
|
-
* This transform rewrites LinkedField nodes with @match and rewrites them
|
66
|
-
* into `LinkedField` nodes with a `supported` argument.
|
67
|
-
*/
|
68
|
-
function matchTransform(context: CompilerContext): CompilerContext {
|
69
|
-
return IRTransformer.transform(
|
70
|
-
context,
|
71
|
-
{
|
72
|
-
// TODO: type IRTransformer to allow changing result type
|
73
|
-
FragmentSpread: (visitFragmentSpread: $FlowFixMe),
|
74
|
-
LinkedField: visitLinkedField,
|
75
|
-
InlineFragment: visitInlineFragment,
|
76
|
-
ScalarField: visitScalarField,
|
77
|
-
},
|
78
|
-
node => ({
|
79
|
-
documentName: node.name,
|
80
|
-
matchesForPath: new Map(),
|
81
|
-
moduleKey: null,
|
82
|
-
parentType: node.type,
|
83
|
-
path: [],
|
84
|
-
}),
|
85
|
-
);
|
86
|
-
}
|
87
|
-
|
88
|
-
function visitInlineFragment(
|
89
|
-
node: InlineFragment,
|
90
|
-
state: State,
|
91
|
-
): InlineFragment {
|
92
|
-
return this.traverse(node, {
|
93
|
-
...state,
|
94
|
-
parentType: node.typeCondition,
|
95
|
-
});
|
96
|
-
}
|
97
|
-
|
98
|
-
function visitScalarField(field: ScalarField): ScalarField {
|
99
|
-
const context: CompilerContext = this.getContext();
|
100
|
-
const schema = context.getSchema();
|
101
|
-
|
102
|
-
if (field.name === JS_FIELD_NAME) {
|
103
|
-
const jsModuleType = schema.getTypeFromString(JS_FIELD_TYPE);
|
104
|
-
if (jsModuleType == null || !schema.isServerType(jsModuleType)) {
|
105
|
-
throw new createUserError(
|
106
|
-
`'${JS_FIELD_NAME}' should be defined on the server schema.`,
|
107
|
-
[field.loc],
|
108
|
-
);
|
109
|
-
}
|
110
|
-
|
111
|
-
if (
|
112
|
-
schema.isScalar(jsModuleType) &&
|
113
|
-
schema.areEqualTypes(schema.getRawType(field.type), jsModuleType)
|
114
|
-
) {
|
115
|
-
throw new createUserError(
|
116
|
-
`Direct use of the '${JS_FIELD_NAME}' field is not allowed, use ` +
|
117
|
-
'@match/@module instead.',
|
118
|
-
[field.loc],
|
119
|
-
);
|
120
|
-
}
|
121
|
-
}
|
122
|
-
return field;
|
123
|
-
}
|
124
|
-
|
125
|
-
function visitLinkedField(node: LinkedField, state: State): LinkedField {
|
126
|
-
const context: CompilerContext = this.getContext();
|
127
|
-
const schema = context.getSchema();
|
128
|
-
|
129
|
-
const matchDirective = node.directives.find(
|
130
|
-
directive => directive.name === 'match',
|
131
|
-
);
|
132
|
-
let moduleKey = null;
|
133
|
-
if (matchDirective != null) {
|
134
|
-
({key: moduleKey} = getLiteralArgumentValues(matchDirective.args));
|
135
|
-
if (
|
136
|
-
moduleKey != null &&
|
137
|
-
(typeof moduleKey !== 'string' ||
|
138
|
-
!moduleKey.startsWith(state.documentName))
|
139
|
-
) {
|
140
|
-
throw createUserError(
|
141
|
-
"Expected the 'key' argument of @match to be a literal string starting " +
|
142
|
-
`with the document name, e.g. '${state.documentName}_<localName>'.`,
|
143
|
-
[
|
144
|
-
(
|
145
|
-
matchDirective.args.find(arg => arg.name === 'key') ??
|
146
|
-
matchDirective
|
147
|
-
).loc,
|
148
|
-
],
|
149
|
-
);
|
150
|
-
}
|
151
|
-
}
|
152
|
-
|
153
|
-
state.path.push(node);
|
154
|
-
const transformedNode: LinkedField = this.traverse(node, {
|
155
|
-
...state,
|
156
|
-
moduleKey,
|
157
|
-
parentType: node.type,
|
158
|
-
});
|
159
|
-
state.path.pop();
|
160
|
-
|
161
|
-
if (matchDirective == null) {
|
162
|
-
return transformedNode;
|
163
|
-
}
|
164
|
-
|
165
|
-
const {parentType} = state;
|
166
|
-
const rawType = schema.getRawType(parentType);
|
167
|
-
if (!(schema.isInterface(rawType) || schema.isObject(rawType))) {
|
168
|
-
throw createUserError(
|
169
|
-
`@match used on incompatible field '${transformedNode.name}'.` +
|
170
|
-
'@match may only be used with fields whose parent type is an ' +
|
171
|
-
`interface or object, got invalid type '${schema.getTypeString(
|
172
|
-
parentType,
|
173
|
-
)}'.`,
|
174
|
-
[node.loc],
|
175
|
-
);
|
176
|
-
}
|
177
|
-
|
178
|
-
const currentField = schema.getFieldConfig(
|
179
|
-
schema.expectField(
|
180
|
-
schema.assertCompositeType(rawType),
|
181
|
-
transformedNode.name,
|
182
|
-
),
|
183
|
-
);
|
184
|
-
|
185
|
-
const supportedArgumentDefinition = currentField.args.find(
|
186
|
-
({name}) => name === SUPPORTED_ARGUMENT_NAME,
|
187
|
-
);
|
188
|
-
if (supportedArgumentDefinition == null) {
|
189
|
-
if (moduleKey == null) {
|
190
|
-
throw createUserError(
|
191
|
-
'@match on a field without the `supported` argument is a no-op, please remove the `@match`.',
|
192
|
-
[node.loc],
|
193
|
-
);
|
194
|
-
}
|
195
|
-
return transformedNode;
|
196
|
-
}
|
197
|
-
|
198
|
-
const supportedArgType = schema.getNullableType(
|
199
|
-
supportedArgumentDefinition.type,
|
200
|
-
);
|
201
|
-
const supportedArgOfType =
|
202
|
-
supportedArgType != null && schema.isList(supportedArgType)
|
203
|
-
? schema.getListItemType(supportedArgType)
|
204
|
-
: null;
|
205
|
-
if (
|
206
|
-
supportedArgType == null ||
|
207
|
-
supportedArgOfType == null ||
|
208
|
-
!schema.isString(schema.getNullableType(supportedArgOfType))
|
209
|
-
) {
|
210
|
-
throw createUserError(
|
211
|
-
`@match used on incompatible field '${transformedNode.name}'. ` +
|
212
|
-
'@match may only be used with fields that accept a ' +
|
213
|
-
"'supported: [String!]!' argument.",
|
214
|
-
[node.loc],
|
215
|
-
);
|
216
|
-
}
|
217
|
-
|
218
|
-
const rawFieldType = schema.getRawType(transformedNode.type);
|
219
|
-
|
220
|
-
if (!schema.isAbstractType(rawFieldType)) {
|
221
|
-
throw createUserError(
|
222
|
-
`@match used on incompatible field '${transformedNode.name}'.` +
|
223
|
-
'@match may only be used with fields that return a union or interface.',
|
224
|
-
[node.loc],
|
225
|
-
);
|
226
|
-
}
|
227
|
-
|
228
|
-
const seenTypes: Map<TypeID, InlineFragment> = new Map();
|
229
|
-
const selections = [];
|
230
|
-
transformedNode.selections.forEach(matchSelection => {
|
231
|
-
if (
|
232
|
-
matchSelection.kind === 'ScalarField' &&
|
233
|
-
matchSelection.name === '__typename'
|
234
|
-
) {
|
235
|
-
selections.push(matchSelection);
|
236
|
-
return;
|
237
|
-
}
|
238
|
-
const moduleImport =
|
239
|
-
matchSelection.kind === 'InlineFragment'
|
240
|
-
? matchSelection.selections[0]
|
241
|
-
: null;
|
242
|
-
if (
|
243
|
-
matchSelection.kind !== 'InlineFragment' ||
|
244
|
-
moduleImport == null ||
|
245
|
-
moduleImport.kind !== 'ModuleImport'
|
246
|
-
) {
|
247
|
-
throw createUserError(
|
248
|
-
'Invalid @match selection: all selections should be ' +
|
249
|
-
'fragment spreads with @module.',
|
250
|
-
[matchSelection.loc],
|
251
|
-
);
|
252
|
-
}
|
253
|
-
const matchedType = matchSelection.typeCondition;
|
254
|
-
seenTypes.set(matchedType, matchSelection);
|
255
|
-
selections.push(matchSelection);
|
256
|
-
});
|
257
|
-
|
258
|
-
if (seenTypes.size === 0) {
|
259
|
-
throw createUserError(
|
260
|
-
'Invalid @match selection: expected at least one @module selection. ' +
|
261
|
-
"Remove @match or add a '...Fragment @module()' selection.",
|
262
|
-
[matchDirective.loc],
|
263
|
-
);
|
264
|
-
}
|
265
|
-
|
266
|
-
const supportedArg = transformedNode.args.find(
|
267
|
-
arg => arg.name === SUPPORTED_ARGUMENT_NAME,
|
268
|
-
);
|
269
|
-
if (supportedArg != null) {
|
270
|
-
throw createUserError(
|
271
|
-
`Invalid @match selection: the '${SUPPORTED_ARGUMENT_NAME}' argument ` +
|
272
|
-
'is automatically added and cannot be supplied explicitly.',
|
273
|
-
[supportedArg.loc],
|
274
|
-
);
|
275
|
-
}
|
276
|
-
|
277
|
-
return {
|
278
|
-
kind: 'LinkedField',
|
279
|
-
alias: transformedNode.alias,
|
280
|
-
args: [
|
281
|
-
...transformedNode.args,
|
282
|
-
{
|
283
|
-
kind: 'Argument',
|
284
|
-
name: SUPPORTED_ARGUMENT_NAME,
|
285
|
-
type: supportedArgumentDefinition.type,
|
286
|
-
value: {
|
287
|
-
kind: 'Literal',
|
288
|
-
loc: node.loc,
|
289
|
-
value: Array.from(seenTypes.keys()).map(type =>
|
290
|
-
schema.getTypeString(type),
|
291
|
-
),
|
292
|
-
},
|
293
|
-
loc: node.loc,
|
294
|
-
},
|
295
|
-
],
|
296
|
-
connection: false,
|
297
|
-
directives: [],
|
298
|
-
handles: null,
|
299
|
-
loc: node.loc,
|
300
|
-
metadata: null,
|
301
|
-
name: transformedNode.name,
|
302
|
-
type: transformedNode.type,
|
303
|
-
selections,
|
304
|
-
};
|
305
|
-
}
|
306
|
-
|
307
|
-
// Transform @module
|
308
|
-
function visitFragmentSpread(
|
309
|
-
spread: FragmentSpread,
|
310
|
-
{documentName, path, matchesForPath, moduleKey: moduleKeyFromParent}: State,
|
311
|
-
): FragmentSpread | InlineFragment {
|
312
|
-
const transformedNode: FragmentSpread = this.traverse(spread);
|
313
|
-
|
314
|
-
const moduleDirective = transformedNode.directives.find(
|
315
|
-
directive => directive.name === 'module',
|
316
|
-
);
|
317
|
-
if (moduleDirective == null) {
|
318
|
-
return transformedNode;
|
319
|
-
}
|
320
|
-
if (spread.args.length !== 0) {
|
321
|
-
throw createUserError(
|
322
|
-
'@module does not support @arguments.',
|
323
|
-
[spread.args[0]?.loc].filter(Boolean),
|
324
|
-
);
|
325
|
-
}
|
326
|
-
|
327
|
-
const context: CompilerContext = this.getContext();
|
328
|
-
const schema = context.getSchema();
|
329
|
-
|
330
|
-
const jsModuleType = schema.asScalarFieldType(
|
331
|
-
schema.getTypeFromString(JS_FIELD_TYPE),
|
332
|
-
);
|
333
|
-
if (jsModuleType == null || !schema.isServerType(jsModuleType)) {
|
334
|
-
throw new createUserError(
|
335
|
-
`'${JS_FIELD_NAME}' should be defined on the server schema.`,
|
336
|
-
[spread.loc],
|
337
|
-
);
|
338
|
-
}
|
339
|
-
|
340
|
-
if (!schema.isScalar(jsModuleType)) {
|
341
|
-
throw createUserError(
|
342
|
-
'Using @module requires the schema to define a scalar ' +
|
343
|
-
`'${JS_FIELD_TYPE}' type.`,
|
344
|
-
);
|
345
|
-
}
|
346
|
-
|
347
|
-
const fragment = context.getFragment(spread.name, spread.loc);
|
348
|
-
if (!schema.isObject(fragment.type)) {
|
349
|
-
throw createUserError(
|
350
|
-
`@module used on invalid fragment spread '...${spread.name}'. @module ` +
|
351
|
-
'may only be used with fragments on a concrete (object) type, ' +
|
352
|
-
`but the fragment has abstract type '${schema.getTypeString(
|
353
|
-
fragment.type,
|
354
|
-
)}'.`,
|
355
|
-
[spread.loc, fragment.loc],
|
356
|
-
);
|
357
|
-
}
|
358
|
-
const field = schema.getFieldByName(fragment.type, JS_FIELD_NAME);
|
359
|
-
if (!field) {
|
360
|
-
throw createUserError(
|
361
|
-
`@module used on invalid fragment spread '...${spread.name}'. @module ` +
|
362
|
-
`requires the fragment type '${schema.getTypeString(
|
363
|
-
fragment.type,
|
364
|
-
)}' to have a ` +
|
365
|
-
`'${JS_FIELD_NAME}(${JS_FIELD_MODULE_ARG}: String! ` +
|
366
|
-
`[${JS_FIELD_ID_ARG}: String]): ${JS_FIELD_TYPE}' field (your ` +
|
367
|
-
"schema may choose to omit the 'id' argument but if present it " +
|
368
|
-
"must accept a 'String').",
|
369
|
-
[moduleDirective.loc],
|
370
|
-
);
|
371
|
-
}
|
372
|
-
const jsField = schema.getFieldConfig(field);
|
373
|
-
|
374
|
-
const jsFieldModuleArg = jsField
|
375
|
-
? jsField.args.find(arg => arg.name === JS_FIELD_MODULE_ARG)
|
376
|
-
: null;
|
377
|
-
const jsFieldIdArg = jsField
|
378
|
-
? jsField.args.find(arg => arg.name === JS_FIELD_ID_ARG)
|
379
|
-
: null;
|
380
|
-
if (
|
381
|
-
jsFieldModuleArg == null ||
|
382
|
-
!schema.isString(schema.getNullableType(jsFieldModuleArg.type)) ||
|
383
|
-
(jsFieldIdArg != null && !schema.isString(jsFieldIdArg.type)) ||
|
384
|
-
jsField.type !== jsModuleType
|
385
|
-
) {
|
386
|
-
throw createUserError(
|
387
|
-
`@module used on invalid fragment spread '...${spread.name}'. @module ` +
|
388
|
-
`requires the fragment type '${schema.getTypeString(
|
389
|
-
fragment.type,
|
390
|
-
)}' to have a ` +
|
391
|
-
`'${JS_FIELD_NAME}(${JS_FIELD_MODULE_ARG}: String! ` +
|
392
|
-
`[${JS_FIELD_ID_ARG}: String]): ${JS_FIELD_TYPE}' field (your ` +
|
393
|
-
"schema may choose to omit the 'id' argument but if present it " +
|
394
|
-
"must accept a 'String').",
|
395
|
-
[moduleDirective.loc],
|
396
|
-
);
|
397
|
-
}
|
398
|
-
|
399
|
-
if (spread.directives.length !== 1) {
|
400
|
-
throw createUserError(
|
401
|
-
`@module used on invalid fragment spread '...${spread.name}'. @module ` +
|
402
|
-
'may not have additional directives.',
|
403
|
-
[spread.loc],
|
404
|
-
);
|
405
|
-
}
|
406
|
-
const {name: moduleName} = getLiteralArgumentValues(moduleDirective.args);
|
407
|
-
if (typeof moduleName !== 'string') {
|
408
|
-
throw createUserError(
|
409
|
-
"Expected the 'name' argument of @module to be a literal string",
|
410
|
-
[(moduleDirective.args.find(arg => arg.name === 'name') ?? spread).loc],
|
411
|
-
);
|
412
|
-
}
|
413
|
-
const parentField = path[path.length - 1];
|
414
|
-
const moduleKey = moduleKeyFromParent ?? documentName;
|
415
|
-
const aliasPath = path.map(x => x.alias).join('.');
|
416
|
-
const moduleId =
|
417
|
-
aliasPath === '' ? documentName : `${documentName}.${aliasPath}`;
|
418
|
-
const typeName = schema.getTypeString(fragment.type);
|
419
|
-
|
420
|
-
let matches = matchesForPath.get(aliasPath);
|
421
|
-
if (matches == null) {
|
422
|
-
if (matchesForPath.size !== 0) {
|
423
|
-
const existingMatchWithKey = Array.from(matchesForPath.values()).find(
|
424
|
-
entry => entry.key === moduleKey,
|
425
|
-
);
|
426
|
-
if (existingMatchWithKey != null) {
|
427
|
-
if (parentField == null) {
|
428
|
-
throw createCompilerError(
|
429
|
-
'Cannot have @module selections at multiple paths unless the selections are within fields.',
|
430
|
-
[spread.loc],
|
431
|
-
);
|
432
|
-
}
|
433
|
-
throw createUserError(
|
434
|
-
'Invalid @module selection: documents with multiple fields ' +
|
435
|
-
"containing 3D selections must specify a unique 'key' value " +
|
436
|
-
`for each field: use '${parentField.alias} @match(key: "${documentName}_<localName>")'.`,
|
437
|
-
[parentField.loc],
|
438
|
-
);
|
439
|
-
}
|
440
|
-
}
|
441
|
-
|
442
|
-
matches = {
|
443
|
-
key: moduleKey,
|
444
|
-
location: parentField?.loc ?? spread.loc,
|
445
|
-
types: new Map(),
|
446
|
-
};
|
447
|
-
matchesForPath.set(aliasPath, matches);
|
448
|
-
}
|
449
|
-
if (moduleKey !== matches.key) {
|
450
|
-
// The user can't override the key locally (per @module),
|
451
|
-
// so this is just an internal sanity check
|
452
|
-
throw createCompilerError(
|
453
|
-
'Invalid @module selection: expected all selections at path ' +
|
454
|
-
`'${aliasPath} to have the same 'key', got '${moduleKey}' and '${matches.key}'.`,
|
455
|
-
[parentField?.loc ?? spread.loc],
|
456
|
-
);
|
457
|
-
}
|
458
|
-
const previousMatchForType = matches.types.get(typeName);
|
459
|
-
if (
|
460
|
-
previousMatchForType != null &&
|
461
|
-
(previousMatchForType.fragment !== spread.name ||
|
462
|
-
previousMatchForType.module !== moduleName)
|
463
|
-
) {
|
464
|
-
throw createUserError(
|
465
|
-
'Invalid @module selection: concrete type ' +
|
466
|
-
`'${typeName}' was matched multiple times at path ` +
|
467
|
-
`'${aliasPath}' but with a different fragment or module name.`,
|
468
|
-
[spread.loc, previousMatchForType.location],
|
469
|
-
);
|
470
|
-
}
|
471
|
-
matches.types.set(typeName, {
|
472
|
-
location: spread.loc,
|
473
|
-
fragment: spread.name,
|
474
|
-
module: moduleName,
|
475
|
-
});
|
476
|
-
|
477
|
-
const normalizationName =
|
478
|
-
getNormalizationOperationName(spread.name) + '.graphql';
|
479
|
-
const componentKey = getModuleComponentKey(moduleKey);
|
480
|
-
const componentField: ScalarField = {
|
481
|
-
alias: componentKey,
|
482
|
-
args: [
|
483
|
-
{
|
484
|
-
kind: 'Argument',
|
485
|
-
name: JS_FIELD_MODULE_ARG,
|
486
|
-
type: jsFieldModuleArg.type,
|
487
|
-
value: {
|
488
|
-
kind: 'Literal',
|
489
|
-
loc: moduleDirective.args[0]?.loc ?? moduleDirective.loc,
|
490
|
-
value: moduleName,
|
491
|
-
},
|
492
|
-
loc: moduleDirective.loc,
|
493
|
-
},
|
494
|
-
jsFieldIdArg != null
|
495
|
-
? {
|
496
|
-
kind: 'Argument',
|
497
|
-
name: JS_FIELD_ID_ARG,
|
498
|
-
type: jsFieldIdArg.type,
|
499
|
-
value: {
|
500
|
-
kind: 'Literal',
|
501
|
-
loc: moduleDirective.args[0]?.loc ?? moduleDirective.loc,
|
502
|
-
value: moduleId,
|
503
|
-
},
|
504
|
-
loc: moduleDirective.loc,
|
505
|
-
}
|
506
|
-
: null,
|
507
|
-
].filter(Boolean),
|
508
|
-
directives: [],
|
509
|
-
handles: null,
|
510
|
-
kind: 'ScalarField',
|
511
|
-
loc: moduleDirective.loc,
|
512
|
-
metadata: {skipNormalizationNode: true},
|
513
|
-
name: JS_FIELD_NAME,
|
514
|
-
type: jsModuleType,
|
515
|
-
};
|
516
|
-
const operationKey = getModuleOperationKey(moduleKey);
|
517
|
-
const operationField: ScalarField = {
|
518
|
-
alias: operationKey,
|
519
|
-
args: [
|
520
|
-
{
|
521
|
-
kind: 'Argument',
|
522
|
-
name: JS_FIELD_MODULE_ARG,
|
523
|
-
type: jsFieldModuleArg.type,
|
524
|
-
value: {
|
525
|
-
kind: 'Literal',
|
526
|
-
loc: moduleDirective.loc,
|
527
|
-
value: normalizationName,
|
528
|
-
},
|
529
|
-
loc: moduleDirective.loc,
|
530
|
-
},
|
531
|
-
jsFieldIdArg != null
|
532
|
-
? {
|
533
|
-
kind: 'Argument',
|
534
|
-
name: JS_FIELD_ID_ARG,
|
535
|
-
type: jsFieldIdArg.type,
|
536
|
-
value: {
|
537
|
-
kind: 'Literal',
|
538
|
-
loc: moduleDirective.args[0]?.loc ?? moduleDirective.loc,
|
539
|
-
value: moduleId,
|
540
|
-
},
|
541
|
-
loc: moduleDirective.loc,
|
542
|
-
}
|
543
|
-
: null,
|
544
|
-
].filter(Boolean),
|
545
|
-
directives: [],
|
546
|
-
handles: null,
|
547
|
-
kind: 'ScalarField',
|
548
|
-
loc: moduleDirective.loc,
|
549
|
-
metadata: {skipNormalizationNode: true},
|
550
|
-
name: JS_FIELD_NAME,
|
551
|
-
type: jsModuleType,
|
552
|
-
};
|
553
|
-
|
554
|
-
return {
|
555
|
-
kind: 'InlineFragment',
|
556
|
-
directives: [],
|
557
|
-
loc: moduleDirective.loc,
|
558
|
-
metadata: null,
|
559
|
-
selections: [
|
560
|
-
{
|
561
|
-
kind: 'ModuleImport',
|
562
|
-
loc: moduleDirective.loc,
|
563
|
-
key: moduleKey,
|
564
|
-
id: moduleId,
|
565
|
-
module: moduleName,
|
566
|
-
sourceDocument: documentName,
|
567
|
-
name: spread.name,
|
568
|
-
selections: [
|
569
|
-
{
|
570
|
-
...spread,
|
571
|
-
directives: spread.directives.filter(
|
572
|
-
directive => directive !== moduleDirective,
|
573
|
-
),
|
574
|
-
},
|
575
|
-
operationField,
|
576
|
-
componentField,
|
577
|
-
],
|
578
|
-
},
|
579
|
-
],
|
580
|
-
typeCondition: fragment.type,
|
581
|
-
};
|
582
|
-
}
|
583
|
-
|
584
|
-
module.exports = {
|
585
|
-
SCHEMA_EXTENSION,
|
586
|
-
transform: matchTransform,
|
587
|
-
};
|