From c0c41048fa61c34bb3249a431cd41b206dc37e7c Mon Sep 17 00:00:00 2001 From: Croos3r Date: Sat, 7 Oct 2023 16:29:16 +0200 Subject: [PATCH] fix(workflow-service): now sending previous workflow area identifier and area identifiers Took 20 minutes Took 5 seconds --- .../entities/workflow-area.entity.ts | 6 +-- .../back/src/workflows/workflows.service.ts | 40 +++++++++++++++---- 2 files changed, 36 insertions(+), 10 deletions(-) diff --git a/backend/back/src/workflows/entities/workflow-area.entity.ts b/backend/back/src/workflows/entities/workflow-area.entity.ts index aed354f0..08d231ef 100644 --- a/backend/back/src/workflows/entities/workflow-area.entity.ts +++ b/backend/back/src/workflows/entities/workflow-area.entity.ts @@ -18,9 +18,9 @@ export default class WorkflowArea { actionOfWorkflow!: Workflow; @ManyToOne(() => WorkflowArea, { nullable: true, onDelete: "CASCADE" }) - previousArea!: WorkflowArea; - @OneToMany(() => WorkflowArea, (reactions) => reactions.previousArea, { nullable: true, onDelete: "CASCADE" }) - nextReactions!: WorkflowArea[]; + previousWorkflowArea!: WorkflowArea; + @OneToMany(() => WorkflowArea, (reactions) => reactions.previousWorkflowArea, { nullable: true, onDelete: "CASCADE" }) + nextWorkflowReactions!: WorkflowArea[]; @ApiProperty({ type: () => Area, diff --git a/backend/back/src/workflows/workflows.service.ts b/backend/back/src/workflows/workflows.service.ts index 0061c575..1768b91c 100644 --- a/backend/back/src/workflows/workflows.service.ts +++ b/backend/back/src/workflows/workflows.service.ts @@ -24,7 +24,7 @@ export class WorkflowsService { async getWorkflowWithAreas(id: string, ownerId: string) { const workflow = await this.workflowRepository.findOne({ where: { id, ownerId }, - relations: { action: true, reactions: true }, + relations: { action: true, reactions: { previousWorkflowArea: true, area: true } }, }); if (!workflow) throw new NotFoundException(`Workflow ${id} not found.`); const { name, active, reactions, action } = workflow; @@ -33,21 +33,47 @@ export class WorkflowsService { name, active, action, - reactions, + reactions: reactions.map( + ({ + id, + parameters, + previousWorkflowArea: { id: previousWorkflowAreaId }, + area: { id: areaId, serviceId: areaServiceId }, + }) => ({ + id, + previousWorkflowAreaId, + areaId, + areaServiceId, + parameters, + }), + ), }; } async getWorkflowsWithAreas(ownerId: string) { const workflows = await this.workflowRepository.find({ where: { ownerId }, - relations: { action: true, reactions: true }, + relations: { action: true, reactions: { previousWorkflowArea: true, area: true } }, }); return workflows.map(({ id, name, active, action, reactions }) => ({ id, name, active, action, - reactions, + reactions: reactions.map( + ({ + id, + parameters, + previousWorkflowArea: { id: previousWorkflowAreaId }, + area: { id: areaId, serviceId: areaServiceId }, + }) => ({ + id, + previousWorkflowAreaId, + areaId, + areaServiceId, + parameters, + }), + ), })); } @@ -155,10 +181,10 @@ export class WorkflowsService { reactions.map(async (reaction) => await this.createWorkflowArea(reaction, workflow)), ); for (const dbReaction of dbReactions) { - if (!dbReaction.previousArea) { + if (!dbReaction.previousWorkflowArea) { const { previousAreaId } = reactions.find((reaction) => reaction.id === dbReaction.id); - dbReaction.previousArea = [action, ...dbReactions].find((area) => area.id === previousAreaId); - if (!dbReaction.previousArea) + dbReaction.previousWorkflowArea = [action, ...dbReactions].find((area) => area.id === previousAreaId); + if (!dbReaction.previousWorkflowArea) throw new NotFoundException(`You did not provide a previous area for area ${dbReaction.id}.`); } }