UNPKG

@neo4j/graphql

Version:

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

77 lines 3.66 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. */ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.TopLevelCreateMutationOperation = void 0; const cypher_builder_1 = __importDefault(require("@neo4j/cypher-builder")); const utils_1 = require("../../../../utils/utils"); const operations_1 = require("./operations"); /** Wrapper over createOperation for top level create, that support multiple create operations * This extends Operation because we don't need the mutationOperation API for top level */ class TopLevelCreateMutationOperation extends operations_1.Operation { constructor({ createOperations, projectionOperations, }) { super(); this.createOperations = []; this.createOperations = createOperations; this.projectionOperations = projectionOperations; } getChildren() { return (0, utils_1.filterTruthy)([...this.createOperations, ...this.projectionOperations]); } transpile(context) { if (!context.hasTarget()) { throw new Error("No parent node found!"); } const subqueries = this.createOperations.map((field) => { const { clauses, projectionExpr } = field.transpile(context); return cypher_builder_1.default.utils.concat(...clauses, ...field.getAuthorizationSubqueries(context), new cypher_builder_1.default.Return([projectionExpr, context.returnVariable])); }); const unionStatement = new cypher_builder_1.default.Call(new cypher_builder_1.default.Union(...subqueries)); const projection = this.getProjectionClause(context); return { projectionExpr: context.returnVariable, clauses: [unionStatement, projection], }; } getProjectionClause(context) { const projectionOperation = this.projectionOperations[0]; // TODO: multiple projection operations not supported if (!projectionOperation) { return new cypher_builder_1.default.Finish(); } const subqueries = projectionOperation .getSubqueries(context) .map((sq) => new cypher_builder_1.default.Call(sq, [context.target])); const projectionField = Object.values(projectionOperation.getProjectionField())[0]; if (!projectionField) { throw new Error("Fatal Error: Invalid projectionField, please contact support"); } const returnClause = new cypher_builder_1.default.Return([cypher_builder_1.default.collect(projectionField), "data"]); let extraWith; if (subqueries.length > 0) { extraWith = new cypher_builder_1.default.With(context.target); } return cypher_builder_1.default.utils.concat(extraWith, ...subqueries, returnClause); } } exports.TopLevelCreateMutationOperation = TopLevelCreateMutationOperation; //# sourceMappingURL=TopLevelCreateMutationOperation.js.map