mirror of
				https://github.com/strapi/strapi.git
				synced 2025-10-31 01:47:13 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| const { stringEquals } = require('@strapi/utils/lib');
 | |
| const { trim } = require('lodash/fp');
 | |
| const has = require('lodash/has');
 | |
| const { getService } = require('../utils');
 | |
| const {
 | |
|   validateApiTokenCreationInput,
 | |
|   validateApiTokenUpdateInput,
 | |
| } = require('../validation/api-tokens');
 | |
| 
 | |
| module.exports = {
 | |
|   async create(ctx) {
 | |
|     const { body } = ctx.request;
 | |
|     const apiTokenService = getService('api-token');
 | |
| 
 | |
|     /**
 | |
|      * We trim both field to avoid having issues with either:
 | |
|      * - having a space at the end or start of the value.
 | |
|      * - having only spaces as value;
 | |
|      */
 | |
|     const attributes = {
 | |
|       name: trim(body.name),
 | |
|       description: trim(body.description),
 | |
|       type: body.type,
 | |
|     };
 | |
| 
 | |
|     try {
 | |
|       await validateApiTokenCreationInput(attributes);
 | |
|     } catch (err) {
 | |
|       return ctx.badRequest('ValidationError', err);
 | |
|     }
 | |
| 
 | |
|     const alreadyExists = await apiTokenService.exists({ name: attributes.name });
 | |
|     if (alreadyExists) {
 | |
|       return ctx.badRequest('Name already taken');
 | |
|     }
 | |
| 
 | |
|     const apiToken = await apiTokenService.create(attributes);
 | |
|     ctx.created({ data: apiToken });
 | |
|   },
 | |
| 
 | |
|   async list(ctx) {
 | |
|     const apiTokenService = getService('api-token');
 | |
|     const apiTokens = await apiTokenService.list();
 | |
| 
 | |
|     ctx.send({ data: apiTokens });
 | |
|   },
 | |
| 
 | |
|   async revoke(ctx) {
 | |
|     const { id } = ctx.params;
 | |
|     const apiTokenService = getService('api-token');
 | |
|     const apiToken = await apiTokenService.revoke(id);
 | |
| 
 | |
|     ctx.deleted({ data: apiToken });
 | |
|   },
 | |
| 
 | |
|   async get(ctx) {
 | |
|     const { id } = ctx.params;
 | |
|     const apiTokenService = getService('api-token');
 | |
|     const apiToken = await apiTokenService.getById(id);
 | |
| 
 | |
|     if (!apiToken) {
 | |
|       ctx.notFound('API Token not found');
 | |
| 
 | |
|       return;
 | |
|     }
 | |
| 
 | |
|     ctx.send({ data: apiToken });
 | |
|   },
 | |
| 
 | |
|   async update(ctx) {
 | |
|     const { body } = ctx.request;
 | |
|     const { id } = ctx.params;
 | |
|     const apiTokenService = getService('api-token');
 | |
| 
 | |
|     const attributes = body;
 | |
|     /**
 | |
|      * We trim both field to avoid having issues with either:
 | |
|      * - having a space at the end or start of the value.
 | |
|      * - having only spaces as value;
 | |
|      */
 | |
|     if (has(attributes, 'name')) {
 | |
|       attributes.name = trim(body.name);
 | |
|     }
 | |
| 
 | |
|     if (has(attributes, 'description') || attributes.description === null) {
 | |
|       attributes.description = trim(body.description);
 | |
|     }
 | |
| 
 | |
|     try {
 | |
|       await validateApiTokenUpdateInput(attributes);
 | |
|     } catch (err) {
 | |
|       return ctx.badRequest('ValidationError', err);
 | |
|     }
 | |
| 
 | |
|     const apiTokenExists = await apiTokenService.getById(id);
 | |
|     if (!apiTokenExists) {
 | |
|       return ctx.notFound('API token not found');
 | |
|     }
 | |
| 
 | |
|     if (has(attributes, 'name')) {
 | |
|       const nameAlreadyTaken = await apiTokenService.getByName(attributes.name);
 | |
| 
 | |
|       /**
 | |
|        * We cast the ids as string as the one coming from the ctx isn't cast
 | |
|        * as a Number in case it is supposed to be an integer. It remains
 | |
|        * as a string. This way we avoid issues with integers in the db.
 | |
|        */
 | |
|       if (!!nameAlreadyTaken && !stringEquals(nameAlreadyTaken.id, id)) {
 | |
|         return ctx.badRequest('Name already taken');
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     const apiToken = await apiTokenService.update(id, attributes);
 | |
|     ctx.send({ data: apiToken });
 | |
|   },
 | |
| };
 | 
