UNPKG

@neo4j/graphql

Version:

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

47 lines 2.02 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.checkAuthentication = checkAuthentication; const classes_1 = require("../../../../classes"); const constants_1 = require("../../../../constants"); const filter_by_values_1 = require("../../../../translate/authorization/utils/filter-by-values"); function checkAuthentication({ authenticated, operation, context, }) { const schemaLevelAnnotation = context.schemaModel.annotations.authentication; if (schemaLevelAnnotation && schemaLevelAnnotation.operations.has(operation)) { applyAuthentication(schemaLevelAnnotation, context); } const annotation = authenticated.annotations.authentication; if (annotation && annotation.operations.has(operation)) { applyAuthentication(annotation, context); } } function applyAuthentication(annotation, context) { if (!context.authorization.jwt) { throw new classes_1.Neo4jGraphQLError(constants_1.AUTHORIZATION_UNAUTHENTICATED); } if (annotation.jwt) { const { jwt, claims } = context.authorization; const result = (0, filter_by_values_1.filterByValues)(annotation.jwt, jwt, claims); if (!result) { throw new classes_1.Neo4jGraphQLError(constants_1.AUTHORIZATION_UNAUTHENTICATED); } } } //# sourceMappingURL=check-authentication.js.map