From bf7634015dfd045b81fd6a2e47abc9df3c476cfb Mon Sep 17 00:00:00 2001 From: praju-aot Date: Thu, 28 Nov 2024 14:10:50 -0500 Subject: [PATCH 1/3] Feature flags to prevent creation of an application of a certain permit type --- .../dbo.ORBC_FEATURE_FLAG.Table.sql | 93 +++++++++++++++++++ .../application/application.service.ts | 13 +++ 2 files changed, 106 insertions(+) diff --git a/database/mssql/scripts/sampledata/dbo.ORBC_FEATURE_FLAG.Table.sql b/database/mssql/scripts/sampledata/dbo.ORBC_FEATURE_FLAG.Table.sql index 3688e3dcc..df88332e4 100644 --- a/database/mssql/scripts/sampledata/dbo.ORBC_FEATURE_FLAG.Table.sql +++ b/database/mssql/scripts/sampledata/dbo.ORBC_FEATURE_FLAG.Table.sql @@ -118,6 +118,99 @@ VALUES GETUTCDATE() ); + INSERT INTO + [dbo].[ORBC_FEATURE_FLAG] ( + [FEATURE_ID], + [FEATURE_KEY], + [FEATURE_VALUE], + [CONCURRENCY_CONTROL_NUMBER], + [DB_CREATE_USERID], + [DB_CREATE_TIMESTAMP], + [DB_LAST_UPDATE_USERID], + [DB_LAST_UPDATE_TIMESTAMP] + ) +VALUES + ( + '6', + 'TROS', + 'ENABLED', + NULL, + N'dbo', + GETUTCDATE(), + N'dbo', + GETUTCDATE() + ); + +INSERT INTO + [dbo].[ORBC_FEATURE_FLAG] ( + [FEATURE_ID], + [FEATURE_KEY], + [FEATURE_VALUE], + [CONCURRENCY_CONTROL_NUMBER], + [DB_CREATE_USERID], + [DB_CREATE_TIMESTAMP], + [DB_LAST_UPDATE_USERID], + [DB_LAST_UPDATE_TIMESTAMP] + ) +VALUES + ( + '7', + 'TROW', + 'ENABLED', + NULL, + N'dbo', + GETUTCDATE(), + N'dbo', + GETUTCDATE() + ); + + INSERT INTO + [dbo].[ORBC_FEATURE_FLAG] ( + [FEATURE_ID], + [FEATURE_KEY], + [FEATURE_VALUE], + [CONCURRENCY_CONTROL_NUMBER], + [DB_CREATE_USERID], + [DB_CREATE_TIMESTAMP], + [DB_LAST_UPDATE_USERID], + [DB_LAST_UPDATE_TIMESTAMP] + ) +VALUES + ( + '8', + 'STOS', + 'ENABLED', + NULL, + N'dbo', + GETUTCDATE(), + N'dbo', + GETUTCDATE() + ); + + +INSERT INTO + [dbo].[ORBC_FEATURE_FLAG] ( + [FEATURE_ID], + [FEATURE_KEY], + [FEATURE_VALUE], + [CONCURRENCY_CONTROL_NUMBER], + [DB_CREATE_USERID], + [DB_CREATE_TIMESTAMP], + [DB_LAST_UPDATE_USERID], + [DB_LAST_UPDATE_TIMESTAMP] + ) +VALUES + ( + '9', + 'MFP', + 'ENABLED', + NULL, + N'dbo', + GETUTCDATE(), + N'dbo', + GETUTCDATE() + ); + SET IDENTITY_INSERT [dbo].[ORBC_FEATURE_FLAG] OFF GO \ No newline at end of file diff --git a/vehicles/src/modules/permit-application-payment/application/application.service.ts b/vehicles/src/modules/permit-application-payment/application/application.service.ts index 5cde7daa3..2cfddbe5d 100644 --- a/vehicles/src/modules/permit-application-payment/application/application.service.ts +++ b/vehicles/src/modules/permit-application-payment/application/application.service.ts @@ -87,6 +87,9 @@ import { ReadPermitLoaDto } from './dto/response/read-permit-loa.dto'; import { CreatePermitLoaDto } from './dto/request/create-permit-loa.dto'; import { PermitLoa } from './entities/permit-loa.entity'; import { LoaDetail } from 'src/modules/special-auth/entities/loa-detail.entity'; +import { getFromCache } from '../../../common/helper/cache.helper'; +import { CacheKey } from '../../../common/enum/cache-key.enum'; +import { FeatureFlagValue } from '../../../common/enum/feature-flag-value.enum'; @Injectable() export class ApplicationService { @@ -123,6 +126,16 @@ export class ApplicationService { currentUser: IUserJWT, companyId: number, ): Promise { + const permitTypeFeatureFlag = (await getFromCache( + this.cacheManager, + CacheKey.FEATURE_FLAG_TYPE, + createApplicationDto.permitType, + )) as FeatureFlagValue; + if (permitTypeFeatureFlag !== FeatureFlagValue.ENABLED) { + throwUnprocessableEntityException( + `Feature Disabled - ${createApplicationDto.permitType}`, + ); + } const id = createApplicationDto.permitId; let fetchExistingApplication: Permit; //If permit id exists assign it to null to create new application. From 78fe1063810b66b4dc75df20714366f32be9cca8 Mon Sep 17 00:00:00 2001 From: praju-aot Date: Thu, 28 Nov 2024 14:11:42 -0500 Subject: [PATCH 2/3] ORV2-3129 Feature flags to prevent creation of an application of a certain permit type --- .../application/company-application.controller.ts | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts b/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts index 5a4f7c6dd..f999d43a9 100644 --- a/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts +++ b/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts @@ -21,6 +21,7 @@ import { ApiOperation, ApiQuery, ApiTags, + ApiUnprocessableEntityResponse, } from '@nestjs/swagger'; import { IUserJWT } from 'src/common/interface/user-jwt.interface'; import { CreateApplicationDto } from './dto/request/create-application.dto'; @@ -142,6 +143,10 @@ export class CompanyApplicationController { description: 'The Permit Application Resource', type: ReadApplicationDto, }) + @ApiUnprocessableEntityResponse({ + description: 'The Applciation could not be processed.', + type: ExceptionDto, + }) @Permissions({ allowedBCeIDRoles: CLIENT_USER_ROLE_LIST, allowedIdirRoles: [ From f778cf49edf164be2296b13ee44378214504ca5f Mon Sep 17 00:00:00 2001 From: Praveen Raju <80779423+praju-aot@users.noreply.github.com> Date: Thu, 28 Nov 2024 14:20:38 -0500 Subject: [PATCH 3/3] Update vehicles/src/modules/permit-application-payment/application/company-application.controller.ts Co-authored-by: Krishnan Subramanian <84348052+krishnan-aot@users.noreply.github.com> Signed-off-by: Praveen Raju <80779423+praju-aot@users.noreply.github.com> --- .../application/company-application.controller.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts b/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts index f999d43a9..b6da814b8 100644 --- a/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts +++ b/vehicles/src/modules/permit-application-payment/application/company-application.controller.ts @@ -144,7 +144,7 @@ export class CompanyApplicationController { type: ReadApplicationDto, }) @ApiUnprocessableEntityResponse({ - description: 'The Applciation could not be processed.', + description: 'The Application could not be processed.', type: ExceptionDto, }) @Permissions({