UNPKG

@neo4j/graphql

Version:

A GraphQL to Cypher query execution layer for Neo4j and JavaScript GraphQL implementations

173 lines 7.79 kB
"use strict"; /* * Copyright (c) "Neo4j" * Neo4j Sweden AB [http://neo4j.com] * * This file is part of Neo4j. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ Object.defineProperty(exports, "__esModule", { value: true }); exports.withConnectInputType = withConnectInputType; exports.augmentConnectInputTypeWithConnectFieldInput = augmentConnectInputTypeWithConnectFieldInput; exports.withConnectFieldInputType = withConnectFieldInputType; const constants_1 = require("../../constants"); const ConcreteEntityAdapter_1 = require("../../schema-model/entity/model-adapters/ConcreteEntityAdapter"); const InterfaceEntityAdapter_1 = require("../../schema-model/entity/model-adapters/InterfaceEntityAdapter"); const UnionEntityAdapter_1 = require("../../schema-model/entity/model-adapters/UnionEntityAdapter"); const utils_1 = require("./utils"); const where_input_1 = require("./where-input"); function withConnectInputType({ entityAdapter, composer, }) { if (entityAdapter instanceof ConcreteEntityAdapter_1.ConcreteEntityAdapter) { return composer.getOrCreateITC(entityAdapter.operations.connectInputTypeName); } return composer.getOrCreateITC(entityAdapter.operations.connectInputTypeName); } function augmentConnectInputTypeWithConnectFieldInput({ relationshipAdapter, composer, deprecatedDirectives, }) { if (relationshipAdapter.source instanceof UnionEntityAdapter_1.UnionEntityAdapter) { throw new Error("Unexpected union source"); } const connectFieldInput = makeConnectInputType({ relationshipAdapter, composer, deprecatedDirectives, }); if (!connectFieldInput) { return; } const connectInput = withConnectInputType({ entityAdapter: relationshipAdapter.source, composer, }); if (!connectInput) { return; } const relationshipField = makeConnectInputTypeRelationshipField({ relationshipAdapter, connectFieldInput, deprecatedDirectives, }); connectInput.addFields(relationshipField); } function makeConnectInputType({ relationshipAdapter, composer, deprecatedDirectives, }) { if (relationshipAdapter.target instanceof UnionEntityAdapter_1.UnionEntityAdapter) { return withUnionConnectInputType({ relationshipAdapter, composer, deprecatedDirectives }); } return withConnectFieldInputType({ relationshipAdapter, composer }); } function makeConnectInputTypeRelationshipField({ relationshipAdapter, connectFieldInput, deprecatedDirectives, }) { if (relationshipAdapter.target instanceof UnionEntityAdapter_1.UnionEntityAdapter) { return { [relationshipAdapter.name]: { type: connectFieldInput, directives: deprecatedDirectives, }, }; } return { [relationshipAdapter.name]: { type: relationshipAdapter.isList ? connectFieldInput.NonNull.List : connectFieldInput, directives: deprecatedDirectives, }, }; } function withUnionConnectInputType({ relationshipAdapter, composer, deprecatedDirectives, }) { const typeName = relationshipAdapter.operations.unionConnectInputTypeName; if (!relationshipAdapter.nestedOperations.has(constants_1.RelationshipNestedOperationsOption.CONNECT)) { return; } if (composer.has(typeName)) { return composer.getITC(typeName); } const fields = makeUnionConnectInputTypeFields({ relationshipAdapter, composer, deprecatedDirectives }); if (!Object.keys(fields).length) { return; } const connectInput = composer.createInputTC({ name: typeName, fields, }); return connectInput; } function makeUnionConnectInputTypeFields({ relationshipAdapter, composer, deprecatedDirectives, }) { const fields = {}; if (!(relationshipAdapter.target instanceof UnionEntityAdapter_1.UnionEntityAdapter)) { throw new Error("Expected union target"); } for (const memberEntity of relationshipAdapter.target.concreteEntities) { const fieldInput = withConnectFieldInputType({ relationshipAdapter, ifUnionMemberEntity: memberEntity, composer, }); if (fieldInput) { fields[memberEntity.name] = { type: relationshipAdapter.isList ? fieldInput.NonNull.List : fieldInput, directives: deprecatedDirectives, }; } } return fields; } function withConnectFieldInputType({ relationshipAdapter, composer, ifUnionMemberEntity, }) { const typeName = relationshipAdapter.operations.getConnectFieldInputTypeName(ifUnionMemberEntity); if (!relationshipAdapter.nestedOperations.has(constants_1.RelationshipNestedOperationsOption.CONNECT)) { return; } if (composer.has(typeName)) { return composer.getITC(typeName); } const connectFieldInput = composer.createInputTC({ name: typeName, fields: makeConnectFieldInputTypeFields({ relationshipAdapter, composer, ifUnionMemberEntity }), }); return connectFieldInput; } function makeConnectFieldInputTypeFields({ relationshipAdapter, composer, ifUnionMemberEntity, }) { const fields = {}; if (relationshipAdapter.hasCreateInputFields) { fields["edge"] = relationshipAdapter.operations.edgeCreateInputTypeName; } if (relationshipAdapter.target instanceof ConcreteEntityAdapter_1.ConcreteEntityAdapter) { fields["where"] = (0, where_input_1.withConnectWhereFieldInputType)(relationshipAdapter.target, composer); if ((0, utils_1.relationshipTargetHasRelationshipWithNestedOperation)(relationshipAdapter.target, constants_1.RelationshipNestedOperationsOption.CONNECT)) { const connectInput = withConnectInputType({ entityAdapter: relationshipAdapter.target, composer }); if (connectInput) { fields["connect"] = relationshipAdapter.isList ? connectInput.NonNull.List : connectInput; } } } else if (relationshipAdapter.target instanceof InterfaceEntityAdapter_1.InterfaceEntityAdapter) { fields["where"] = (0, where_input_1.withConnectWhereFieldInputType)(relationshipAdapter.target, composer); const connectTypename = relationshipAdapter.target.operations.connectInputTypeName; const hasNestedRelationships = relationshipAdapter.target.relationshipDeclarations.size > 0; if (composer.has(connectTypename) || hasNestedRelationships) { const connectInputType = composer.getOrCreateITC(connectTypename); fields["connect"] = connectInputType; } } else { if (!ifUnionMemberEntity) { throw new Error("Member Entity required."); } fields["where"] = (0, where_input_1.withConnectWhereFieldInputType)(ifUnionMemberEntity, composer); if (ifUnionMemberEntity.relationships.size) { const connectInputType = withConnectInputType({ entityAdapter: ifUnionMemberEntity, composer }); if (connectInputType) { fields["connect"] = relationshipAdapter.isList ? connectInputType.NonNull.List : connectInputType; } } } return fields; } //# sourceMappingURL=connect-input.js.map