UNPKG

dino-express

Version:

DinO enabled REST framework based on express

42 lines 1.88 kB
"use strict"; // Copyright 2025 Quirino Brizi // // 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 // // https://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.ApiKeySecurityValidationHandler = void 0; const dino_core_1 = require("dino-core"); const client_http_exception_1 = require("../exception/client.http.exception"); const AbstractSecurityValidationHandler_1 = require("./AbstractSecurityValidationHandler"); class ApiKeySecurityValidationHandler extends AbstractSecurityValidationHandler_1.AbstractSecurityValidationHandler { handle(req, _res, next, config) { const token = this.getToken(this.getAuthType(), config, req); if (dino_core_1.ObjectHelper.isDefined(token)) { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion if (this.validateApiKeyAuth(token, config)) { next(); } else { next(client_http_exception_1.ClientHttpException.create(401, 'Unauthorized')); } } next(client_http_exception_1.ClientHttpException.create(401, 'Unauthorized')); } canHandle(type) { return type === this.getAuthType(); } getAuthType() { return 'apiKey'; } } exports.ApiKeySecurityValidationHandler = ApiKeySecurityValidationHandler; //# sourceMappingURL=ApiKeySecurityValidationHandler.js.map