UNPKG

n8n

Version:

n8n Workflow Automation Tool

113 lines 5.61 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); } }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApiKeysController = exports.isApiEnabledMiddleware = void 0; const api_types_1 = require("@n8n/api-types"); const decorators_1 = require("@n8n/decorators"); const permissions_1 = require("@n8n/permissions"); const bad_request_error_1 = require("../errors/response-errors/bad-request.error"); const event_service_1 = require("../events/event.service"); const public_api_1 = require("../public-api"); const public_api_key_service_1 = require("../services/public-api-key.service"); const isApiEnabledMiddleware = (_, res, next) => { if ((0, public_api_1.isApiEnabled)()) { next(); } else { res.status(404).end(); } }; exports.isApiEnabledMiddleware = isApiEnabledMiddleware; let ApiKeysController = class ApiKeysController { constructor(eventService, publicApiKeyService) { this.eventService = eventService; this.publicApiKeyService = publicApiKeyService; } async createApiKey(req, _res, body) { if (!this.publicApiKeyService.apiKeyHasValidScopesForRole(req.user.role, body.scopes)) { throw new bad_request_error_1.BadRequestError('Invalid scopes for user role'); } const newApiKey = await this.publicApiKeyService.createPublicApiKeyForUser(req.user, body); this.eventService.emit('public-api-key-created', { user: req.user, publicApi: false }); return { ...newApiKey, apiKey: this.publicApiKeyService.redactApiKey(newApiKey.apiKey), rawApiKey: newApiKey.apiKey, expiresAt: body.expiresAt, }; } async getApiKeys(req) { const apiKeys = await this.publicApiKeyService.getRedactedApiKeysForUser(req.user); return apiKeys; } async deleteApiKey(req, _res, apiKeyId) { await this.publicApiKeyService.deleteApiKeyForUser(req.user, apiKeyId); this.eventService.emit('public-api-key-deleted', { user: req.user, publicApi: false }); return { success: true }; } async updateApiKey(req, _res, apiKeyId, body) { if (!this.publicApiKeyService.apiKeyHasValidScopesForRole(req.user.role, body.scopes)) { throw new bad_request_error_1.BadRequestError('Invalid scopes for user role'); } await this.publicApiKeyService.updateApiKeyForUser(req.user, apiKeyId, body); return { success: true }; } async getApiKeyScopes(req, _res) { const { role } = req.user; const scopes = (0, permissions_1.getApiKeyScopesForRole)(role); return scopes; } }; exports.ApiKeysController = ApiKeysController; __decorate([ (0, decorators_1.Post)('/', { middlewares: [exports.isApiEnabledMiddleware] }), __param(2, decorators_1.Body), __metadata("design:type", Function), __metadata("design:paramtypes", [Object, Response, api_types_1.CreateApiKeyRequestDto]), __metadata("design:returntype", Promise) ], ApiKeysController.prototype, "createApiKey", null); __decorate([ (0, decorators_1.Get)('/', { middlewares: [exports.isApiEnabledMiddleware] }), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", Promise) ], ApiKeysController.prototype, "getApiKeys", null); __decorate([ (0, decorators_1.Delete)('/:id', { middlewares: [exports.isApiEnabledMiddleware] }), __param(2, (0, decorators_1.Param)('id')), __metadata("design:type", Function), __metadata("design:paramtypes", [Object, Response, String]), __metadata("design:returntype", Promise) ], ApiKeysController.prototype, "deleteApiKey", null); __decorate([ (0, decorators_1.Patch)('/:id', { middlewares: [exports.isApiEnabledMiddleware] }), __param(2, (0, decorators_1.Param)('id')), __param(3, decorators_1.Body), __metadata("design:type", Function), __metadata("design:paramtypes", [Object, Response, String, api_types_1.UpdateApiKeyRequestDto]), __metadata("design:returntype", Promise) ], ApiKeysController.prototype, "updateApiKey", null); __decorate([ (0, decorators_1.Get)('/scopes', { middlewares: [exports.isApiEnabledMiddleware] }), __metadata("design:type", Function), __metadata("design:paramtypes", [Object, Response]), __metadata("design:returntype", Promise) ], ApiKeysController.prototype, "getApiKeyScopes", null); exports.ApiKeysController = ApiKeysController = __decorate([ (0, decorators_1.RestController)('/api-keys'), __metadata("design:paramtypes", [event_service_1.EventService, public_api_key_service_1.PublicApiKeyService]) ], ApiKeysController); //# sourceMappingURL=api-keys.controller.js.map