This repository has been archived on 2025-12-25. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
qmi-cloud/server/routes/api-apikeys.js
2021-11-10 10:01:18 +01:00

139 lines
3.3 KiB
JavaScript

const express = require('express');
const router = express.Router();
const db = require('qmi-cloud-common/mongo');
const passport = require('../passport');
/**
* @swagger
* /apikeys:
* get:
* description: Get all API keys
* summary: Get all API keys
* tags:
* - admin
* parameters:
* - name: filter
* in: query
* required: false
* type: object
* content:
* application/json:
* schema:
* type: object
* produces:
* - application/json
* responses:
* 200:
* description: API KEYS
*/
router.get('/', passport.ensureAuthenticatedAndAdmin, async (req, res, next) => {
try {
const filter = req.query.filter? JSON.parse(req.query.filter) : {};
const result = await db.apiKey.get(filter);
return res.json(result);
} catch (error) {
next(error);
}
});
/**
* @swagger
* /apikeys/{userId}:
* post:
* description: Create an API for the userId
* summary: Create an API for the userId
* tags:
* - admin
* produces:
* - application/json
* parameters:
* - name: userId
* in: path
* type: string
* required: true
* requestBody:
* required: true
* content:
* application/json:
* schema:
* type: object
* properties:
* description:
* type: string
* responses:
* 200:
* description: API KEY
*/
router.post('/:userId', passport.ensureAuthenticatedAndAdmin, async (req, res, next) => {
try {
const user = await db.user.getById(req.params.userId);
if ( !user ) {
res.status(404).json({"err": "user not found"});
}
var body = req.body;
body.user = req.params.userId;
const result = await db.apiKey.add(body);
return res.json(result);
} catch (error) {
next(error);
}
});
/**
* @swagger
* /apikeys/{id}/revoke:
* put:
* description: Revoke API Key
* summary: Revoke API Key
* tags:
* - admin
* produces:
* - application/json
* parameters:
* - name: id
* in: path
* type: string
* required: true
* responses:
* 200:
* description: API KEY
*/
router.put('/:id/revoke', passport.ensureAuthenticatedAndAdmin, async (req, res, next) => {
try {
const result = await db.apiKey.update(req.params.id, {"isActive": false});
return res.json(result);
} catch (error) {
next(error);
}
});
/**
* @swagger
* /apikeys/{id}:
* delete:
* description: Delete API Key
* summary: Delete API Key
* tags:
* - admin
* produces:
* - application/json
* parameters:
* - name: id
* in: path
* type: string
* required: true
* responses:
* 200:
* description: API KEY
*/
router.delete('/:id', passport.ensureAuthenticatedAndAdmin, async (req, res, next) => {
try {
const result = await db.apiKey.del(req.params.id);
return res.json(result);
} catch (error) {
next(error);
}
});
module.exports = router;