From 07e8a351bb4379886af403aa4048a68d838afe3a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ivar=20Conradi=20=C3=98sthus?= Date: Wed, 8 Feb 2023 19:57:21 +0100 Subject: [PATCH] Fix/show tag events (#3064) This PR fixes two issues with events today: 1. Feature toggles "Event log" must include all events, regardless of the project. This is important as feature toggles may move between 2. Add/remove tags on a feature toggle events should include project id in order to show up in the project specific event log. --- .../FeatureView/FeatureLog/FeatureLog.tsx | 7 +------ src/lib/services/feature-tag-service.ts | 17 +++++++++++++---- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/frontend/src/component/feature/FeatureView/FeatureLog/FeatureLog.tsx b/frontend/src/component/feature/FeatureView/FeatureLog/FeatureLog.tsx index 8ff03d1d48..9596c4d210 100644 --- a/frontend/src/component/feature/FeatureView/FeatureLog/FeatureLog.tsx +++ b/frontend/src/component/feature/FeatureView/FeatureLog/FeatureLog.tsx @@ -20,12 +20,7 @@ const FeatureLog = () => { return ( - + ); }; diff --git a/src/lib/services/feature-tag-service.ts b/src/lib/services/feature-tag-service.ts index caf95328b1..2a67dd3431 100644 --- a/src/lib/services/feature-tag-service.ts +++ b/src/lib/services/feature-tag-service.ts @@ -1,9 +1,8 @@ import NotFoundError from '../error/notfound-error'; import { Logger } from '../logger'; -import { nameSchema } from '../schema/feature-schema'; import { FEATURE_TAGGED, FEATURE_UNTAGGED, TAG_CREATED } from '../types/events'; import { IUnleashConfig } from '../types/option'; -import { IUnleashStores } from '../types/stores'; +import { IFeatureToggleStore, IUnleashStores } from '../types/stores'; import { tagSchema } from './tag-schema'; import { IFeatureTagStore } from '../types/stores/feature-tag-store'; import { IEventStore } from '../types/stores/event-store'; @@ -15,6 +14,8 @@ class FeatureTagService { private featureTagStore: IFeatureTagStore; + private featureToggleStore: IFeatureToggleStore; + private eventStore: IEventStore; private logger: Logger; @@ -24,12 +25,17 @@ class FeatureTagService { tagStore, featureTagStore, eventStore, - }: Pick, + featureToggleStore, + }: Pick< + IUnleashStores, + 'tagStore' | 'featureTagStore' | 'eventStore' | 'featureToggleStore' + >, { getLogger }: Pick, ) { this.logger = getLogger('/services/feature-tag-service.ts'); this.tagStore = tagStore; this.featureTagStore = featureTagStore; + this.featureToggleStore = featureToggleStore; this.eventStore = eventStore; } @@ -43,7 +49,7 @@ class FeatureTagService { tag: ITag, userName: string, ): Promise { - await nameSchema.validateAsync({ name: featureName }); + const featureToggle = await this.featureToggleStore.get(featureName); const validatedTag = await tagSchema.validateAsync(tag); await this.createTagIfNeeded(validatedTag, userName); await this.featureTagStore.tagFeature(featureName, validatedTag); @@ -52,6 +58,7 @@ class FeatureTagService { type: FEATURE_TAGGED, createdBy: userName, featureName, + project: featureToggle.project, data: validatedTag, }); return validatedTag; @@ -78,11 +85,13 @@ class FeatureTagService { tag: ITag, userName: string, ): Promise { + const featureToggle = await this.featureToggleStore.get(featureName); await this.featureTagStore.untagFeature(featureName, tag); await this.eventStore.store({ type: FEATURE_UNTAGGED, createdBy: userName, featureName, + project: featureToggle.project, data: tag, }); }