mirror of
https://iceshrimp.dev/limepotato/jormungandr-bite.git
synced 2025-01-17 11:01:00 -07:00
60 lines
1.3 KiB
TypeScript
60 lines
1.3 KiB
TypeScript
/**
|
|
* Module dependencies
|
|
*/
|
|
import $ from 'cafy';
|
|
import App from '../../../../../models/app';
|
|
import { isValidNameId } from '../../../../../models/app';
|
|
|
|
/**
|
|
* @swagger
|
|
* /app/nameId/available:
|
|
* note:
|
|
* summary: Check available nameId on creation an application
|
|
* parameters:
|
|
* -
|
|
* name: nameId
|
|
* description: Application unique name
|
|
* in: formData
|
|
* required: true
|
|
* type: string
|
|
*
|
|
* responses:
|
|
* 200:
|
|
* description: Success
|
|
* schema:
|
|
* type: object
|
|
* properties:
|
|
* available:
|
|
* description: Whether nameId is available
|
|
* type: boolean
|
|
*
|
|
* default:
|
|
* description: Failed
|
|
* schema:
|
|
* $ref: "#/definitions/Error"
|
|
*/
|
|
|
|
/**
|
|
* Check available nameId of app
|
|
*
|
|
* @param {any} params
|
|
* @return {Promise<any>}
|
|
*/
|
|
export default async (params: any) => new Promise(async (res, rej) => {
|
|
// Get 'nameId' parameter
|
|
const [nameId, nameIdErr] = $.str.pipe(isValidNameId).get(params.nameId);
|
|
if (nameIdErr) return rej('invalid nameId param');
|
|
|
|
// Get exist
|
|
const exist = await App
|
|
.count({
|
|
nameIdLower: nameId.toLowerCase()
|
|
}, {
|
|
limit: 1
|
|
});
|
|
|
|
// Reply
|
|
res({
|
|
available: exist === 0
|
|
});
|
|
});
|