mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-11 00:08:30 +01:00
fix: legacy feature stale on/off needs to return full toggle
This commit is contained in:
parent
8ad235e77f
commit
3ef7fd2420
@ -22,11 +22,9 @@ import { DEFAULT_ENV } from '../../util/constants';
|
|||||||
const version = 1;
|
const version = 1;
|
||||||
|
|
||||||
class FeatureController extends Controller {
|
class FeatureController extends Controller {
|
||||||
private logger: Logger;
|
private tagService: FeatureTagService;
|
||||||
|
|
||||||
private featureTagService: FeatureTagService;
|
private service: FeatureToggleServiceV2;
|
||||||
|
|
||||||
private featureService2: FeatureToggleServiceV2;
|
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
config: IUnleashConfig,
|
config: IUnleashConfig,
|
||||||
@ -39,9 +37,8 @@ class FeatureController extends Controller {
|
|||||||
>,
|
>,
|
||||||
) {
|
) {
|
||||||
super(config);
|
super(config);
|
||||||
this.featureTagService = featureTagService;
|
this.tagService = featureTagService;
|
||||||
this.featureService2 = featureToggleServiceV2;
|
this.service = featureToggleServiceV2;
|
||||||
this.logger = config.getLogger('/admin-api/feature.ts');
|
|
||||||
|
|
||||||
this.get('/', this.getAllToggles);
|
this.get('/', this.getAllToggles);
|
||||||
this.post('/', this.createToggle, CREATE_FEATURE);
|
this.post('/', this.createToggle, CREATE_FEATURE);
|
||||||
@ -94,7 +91,7 @@ class FeatureController extends Controller {
|
|||||||
|
|
||||||
async getAllToggles(req: Request, res: Response): Promise<void> {
|
async getAllToggles(req: Request, res: Response): Promise<void> {
|
||||||
const query = await this.prepQuery(req.query);
|
const query = await this.prepQuery(req.query);
|
||||||
const features = await this.featureService2.getFeatureToggles(query);
|
const features = await this.service.getFeatureToggles(query);
|
||||||
|
|
||||||
res.json({ version, features });
|
res.json({ version, features });
|
||||||
}
|
}
|
||||||
@ -104,21 +101,19 @@ class FeatureController extends Controller {
|
|||||||
res: Response,
|
res: Response,
|
||||||
): Promise<void> {
|
): Promise<void> {
|
||||||
const name = req.params.featureName;
|
const name = req.params.featureName;
|
||||||
const feature = await this.featureService2.getFeatureToggleLegacy(name);
|
const feature = await this.service.getFeatureToggleLegacy(name);
|
||||||
res.json(feature).end();
|
res.json(feature).end();
|
||||||
}
|
}
|
||||||
|
|
||||||
async listTags(req: Request, res: Response): Promise<void> {
|
async listTags(req: Request, res: Response): Promise<void> {
|
||||||
const tags = await this.featureTagService.listTags(
|
const tags = await this.tagService.listTags(req.params.featureName);
|
||||||
req.params.featureName,
|
|
||||||
);
|
|
||||||
res.json({ version, tags });
|
res.json({ version, tags });
|
||||||
}
|
}
|
||||||
|
|
||||||
async addTag(req: IAuthRequest, res: Response): Promise<void> {
|
async addTag(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
const tag = await this.featureTagService.addTag(
|
const tag = await this.tagService.addTag(
|
||||||
featureName,
|
featureName,
|
||||||
req.body,
|
req.body,
|
||||||
userName,
|
userName,
|
||||||
@ -130,18 +125,14 @@ class FeatureController extends Controller {
|
|||||||
async removeTag(req: IAuthRequest, res: Response): Promise<void> {
|
async removeTag(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName, type, value } = req.params;
|
const { featureName, type, value } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
await this.featureTagService.removeTag(
|
await this.tagService.removeTag(featureName, { type, value }, userName);
|
||||||
featureName,
|
|
||||||
{ type, value },
|
|
||||||
userName,
|
|
||||||
);
|
|
||||||
res.status(200).end();
|
res.status(200).end();
|
||||||
}
|
}
|
||||||
|
|
||||||
async validate(req: Request, res: Response): Promise<void> {
|
async validate(req: Request, res: Response): Promise<void> {
|
||||||
const { name } = req.body;
|
const { name } = req.body;
|
||||||
|
|
||||||
await this.featureService2.validateName(name);
|
await this.service.validateName(name);
|
||||||
res.status(200).end();
|
res.status(200).end();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -151,14 +142,14 @@ class FeatureController extends Controller {
|
|||||||
|
|
||||||
const validatedToggle = await featureSchema.validateAsync(toggle);
|
const validatedToggle = await featureSchema.validateAsync(toggle);
|
||||||
const { enabled } = validatedToggle;
|
const { enabled } = validatedToggle;
|
||||||
const createdFeature = await this.featureService2.createFeatureToggle(
|
const createdFeature = await this.service.createFeatureToggle(
|
||||||
validatedToggle.project,
|
validatedToggle.project,
|
||||||
validatedToggle,
|
validatedToggle,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
const strategies = await Promise.all(
|
const strategies = await Promise.all(
|
||||||
toggle.strategies.map(async (s) =>
|
toggle.strategies.map(async (s) =>
|
||||||
this.featureService2.createStrategy(
|
this.service.createStrategy(
|
||||||
s,
|
s,
|
||||||
createdFeature.project,
|
createdFeature.project,
|
||||||
createdFeature.name,
|
createdFeature.name,
|
||||||
@ -166,7 +157,7 @@ class FeatureController extends Controller {
|
|||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
await this.featureService2.updateEnabled(
|
await this.service.updateEnabled(
|
||||||
createdFeature.project,
|
createdFeature.project,
|
||||||
createdFeature.name,
|
createdFeature.name,
|
||||||
DEFAULT_ENV,
|
DEFAULT_ENV,
|
||||||
@ -188,23 +179,17 @@ class FeatureController extends Controller {
|
|||||||
|
|
||||||
updatedFeature.name = featureName;
|
updatedFeature.name = featureName;
|
||||||
|
|
||||||
const projectId = await this.featureService2.getProjectId(
|
const projectId = await this.service.getProjectId(updatedFeature.name);
|
||||||
updatedFeature.name,
|
|
||||||
);
|
|
||||||
const value = await featureSchema.validateAsync(updatedFeature);
|
const value = await featureSchema.validateAsync(updatedFeature);
|
||||||
|
|
||||||
await this.featureService2.updateFeatureToggle(
|
await this.service.updateFeatureToggle(projectId, value, userName);
|
||||||
projectId,
|
|
||||||
value,
|
|
||||||
userName,
|
|
||||||
);
|
|
||||||
|
|
||||||
await this.featureService2.removeAllStrategiesForEnv(featureName);
|
await this.service.removeAllStrategiesForEnv(featureName);
|
||||||
|
|
||||||
if (updatedFeature.strategies) {
|
if (updatedFeature.strategies) {
|
||||||
await Promise.all(
|
await Promise.all(
|
||||||
updatedFeature.strategies.map(async (s) =>
|
updatedFeature.strategies.map(async (s) =>
|
||||||
this.featureService2.createStrategy(
|
this.service.createStrategy(
|
||||||
s,
|
s,
|
||||||
projectId,
|
projectId,
|
||||||
featureName,
|
featureName,
|
||||||
@ -213,7 +198,7 @@ class FeatureController extends Controller {
|
|||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
await this.featureService2.updateEnabled(
|
await this.service.updateEnabled(
|
||||||
projectId,
|
projectId,
|
||||||
updatedFeature.name,
|
updatedFeature.name,
|
||||||
DEFAULT_ENV,
|
DEFAULT_ENV,
|
||||||
@ -221,8 +206,7 @@ class FeatureController extends Controller {
|
|||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
|
|
||||||
const feature =
|
const feature = await this.service.storeFeatureUpdatedEventLegacy(
|
||||||
await this.featureService2.storeFeatureUpdatedEventLegacy(
|
|
||||||
featureName,
|
featureName,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
@ -235,14 +219,14 @@ class FeatureController extends Controller {
|
|||||||
async toggle(req: IAuthRequest, res: Response): Promise<void> {
|
async toggle(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const projectId = await this.featureService2.getProjectId(featureName);
|
const projectId = await this.service.getProjectId(featureName);
|
||||||
const feature = await this.featureService2.toggle(
|
const feature = await this.service.toggle(
|
||||||
projectId,
|
projectId,
|
||||||
featureName,
|
featureName,
|
||||||
DEFAULT_ENV,
|
DEFAULT_ENV,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
await this.featureService2.storeFeatureUpdatedEventLegacy(
|
await this.service.storeFeatureUpdatedEventLegacy(
|
||||||
featureName,
|
featureName,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
@ -252,15 +236,15 @@ class FeatureController extends Controller {
|
|||||||
async toggleOn(req: IAuthRequest, res: Response): Promise<void> {
|
async toggleOn(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
const projectId = await this.featureService2.getProjectId(featureName);
|
const projectId = await this.service.getProjectId(featureName);
|
||||||
const feature = await this.featureService2.updateEnabled(
|
const feature = await this.service.updateEnabled(
|
||||||
projectId,
|
projectId,
|
||||||
featureName,
|
featureName,
|
||||||
DEFAULT_ENV,
|
DEFAULT_ENV,
|
||||||
true,
|
true,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
await this.featureService2.storeFeatureUpdatedEventLegacy(
|
await this.service.storeFeatureUpdatedEventLegacy(
|
||||||
featureName,
|
featureName,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
@ -270,15 +254,15 @@ class FeatureController extends Controller {
|
|||||||
async toggleOff(req: IAuthRequest, res: Response): Promise<void> {
|
async toggleOff(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
const projectId = await this.featureService2.getProjectId(featureName);
|
const projectId = await this.service.getProjectId(featureName);
|
||||||
const feature = await this.featureService2.updateEnabled(
|
const feature = await this.service.updateEnabled(
|
||||||
projectId,
|
projectId,
|
||||||
featureName,
|
featureName,
|
||||||
DEFAULT_ENV,
|
DEFAULT_ENV,
|
||||||
false,
|
false,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
await this.featureService2.storeFeatureUpdatedEventLegacy(
|
await this.service.storeFeatureUpdatedEventLegacy(
|
||||||
featureName,
|
featureName,
|
||||||
userName,
|
userName,
|
||||||
);
|
);
|
||||||
@ -288,22 +272,24 @@ class FeatureController extends Controller {
|
|||||||
async staleOn(req: IAuthRequest, res: Response): Promise<void> {
|
async staleOn(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
await this.featureService2.updateStale(featureName, true, userName);
|
await this.service.updateStale(featureName, true, userName);
|
||||||
res.status(200).end();
|
const feature = await this.service.getFeatureToggleLegacy(featureName);
|
||||||
|
res.json(feature);
|
||||||
}
|
}
|
||||||
|
|
||||||
async staleOff(req: IAuthRequest, res: Response): Promise<void> {
|
async staleOff(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
await this.featureService2.updateStale(featureName, false, userName);
|
await this.service.updateStale(featureName, false, userName);
|
||||||
res.status(200).end();
|
const feature = await this.service.getFeatureToggleLegacy(featureName);
|
||||||
|
res.json(feature);
|
||||||
}
|
}
|
||||||
|
|
||||||
async archiveToggle(req: IAuthRequest, res: Response): Promise<void> {
|
async archiveToggle(req: IAuthRequest, res: Response): Promise<void> {
|
||||||
const { featureName } = req.params;
|
const { featureName } = req.params;
|
||||||
const userName = extractUsername(req);
|
const userName = extractUsername(req);
|
||||||
|
|
||||||
await this.featureService2.archiveToggle(featureName, userName);
|
await this.service.archiveToggle(featureName, userName);
|
||||||
res.status(200).end();
|
res.status(200).end();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user