@neo4j/graphql
Version:
A GraphQL to Cypher query execution layer for Neo4j and JavaScript GraphQL implementations
173 lines • 7.79 kB
JavaScript
;
/*
* 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