mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-01 00:08:27 +01:00
e889d8e29c
This adds support for multi project tokens to be created. Backward compatibility is handled at 3 different layers here: - The API is made backwards compatible though a permissive data type that accepts either a project?: string or projects?: string[] property, validation is done through JOI here, which ensures that projects and project are not set together. In the case of neither, this defaults to the previous default of ALL_PROJECTS - The service layer method to handle adding tokens has been made tolerant to either of the above case and has been deprecated, a new method supporting only the new structure of using projects has been added - Existing compatibility for consumers of Unleash as a library should not be affected either, the ApiUser constructor is now tolerant to the the first input and will internally map to the new cleaned structure
28 lines
973 B
TypeScript
28 lines
973 B
TypeScript
import joi from 'joi';
|
|
import { ALL, ApiTokenType } from '../types/models/api-token';
|
|
import { DEFAULT_ENV } from '../util/constants';
|
|
|
|
export const createApiToken = joi
|
|
.object()
|
|
.keys({
|
|
username: joi.string().required(),
|
|
type: joi
|
|
.string()
|
|
.lowercase()
|
|
.required()
|
|
.valid(ApiTokenType.ADMIN, ApiTokenType.CLIENT),
|
|
expiresAt: joi.date().optional(),
|
|
project: joi.when('projects', {
|
|
not: joi.required(),
|
|
then: joi.string().optional().default(ALL),
|
|
}),
|
|
projects: joi.array().min(0).optional(),
|
|
environment: joi.when('type', {
|
|
is: joi.string().valid(ApiTokenType.CLIENT),
|
|
then: joi.string().optional().default(DEFAULT_ENV),
|
|
otherwise: joi.string().optional().default(ALL),
|
|
}),
|
|
})
|
|
.nand('project', 'projects')
|
|
.options({ stripUnknown: true, allowUnknown: false, abortEarly: false });
|