Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

IMN-213 Fix document update based on descriptor state in catalog-process #185

Merged
merged 110 commits into from
Feb 13, 2024
Merged
Show file tree
Hide file tree
Changes from 81 commits
Commits
Show all changes
110 commits
Select commit Hold shift + click to select a range
fcef976
Renaming
taglioni-r Jan 11, 2024
57789f5
Implement more tests
taglioni-r Jan 11, 2024
9fe8914
Use retrieveDescriptor
taglioni-r Jan 11, 2024
a64efaf
Implement more tests
taglioni-r Jan 11, 2024
0e46486
Implement more tests
taglioni-r Jan 11, 2024
6b61497
Minor refactor
taglioni-r Jan 15, 2024
d94ed28
Implement tests
taglioni-r Jan 15, 2024
ccd3fdc
Implement more tests
taglioni-r Jan 16, 2024
96daa0d
Add to do
taglioni-r Jan 16, 2024
183b1c6
Merge branch 'main' into IMN-145-implement-remaining-tests-in-catalog…
taglioni-r Jan 16, 2024
45ec14a
Implement more tests
taglioni-r Jan 17, 2024
be84946
Fix in catalog readModelService
taglioni-r Jan 17, 2024
3d7d12a
Remove not needed check
taglioni-r Jan 17, 2024
c68f015
Implement more tests
taglioni-r Jan 18, 2024
ebaa361
Add missing error
taglioni-r Jan 18, 2024
f55fbd1
Add missing error
taglioni-r Jan 18, 2024
719af1c
Add missing error
taglioni-r Jan 18, 2024
c50049d
Implement more tests
taglioni-r Jan 18, 2024
b02b13b
Remove error
taglioni-r Jan 18, 2024
ae6d93d
Improve data coherence
taglioni-r Jan 18, 2024
6a23fa1
Fix descriptor version
taglioni-r Jan 19, 2024
44e2f51
Implement more tests
taglioni-r Jan 19, 2024
7852f3a
Remove console log
taglioni-r Jan 19, 2024
aecdecf
Improve data coherence
taglioni-r Jan 19, 2024
26fe35a
Merge branch 'main' into IMN-145-implement-remaining-tests-in-catalog…
taglioni-r Jan 22, 2024
b18320b
Use retrieveDescriptor
taglioni-r Jan 11, 2024
8bb624b
Minor refactor
taglioni-r Jan 15, 2024
38804b4
Fix in catalog readModelService
taglioni-r Jan 17, 2024
863ae92
Remove not needed check
taglioni-r Jan 17, 2024
e7bfde5
Add missing error
taglioni-r Jan 18, 2024
a8db816
Add missing error
taglioni-r Jan 18, 2024
d4f7ced
Add missing error
taglioni-r Jan 18, 2024
986ff04
Remove error
taglioni-r Jan 18, 2024
cff3ffb
Fix descriptor version
taglioni-r Jan 19, 2024
a76a369
Fix tests
taglioni-r Jan 22, 2024
4ec69d1
Refactor
taglioni-r Jan 22, 2024
56bf3e8
Fix test
taglioni-r Jan 22, 2024
606bfb9
Merge branch 'main' into refactor-and-bug-fixing-in-catalog-process
taglioni-r Jan 22, 2024
523f905
Fix after merge
taglioni-r Jan 22, 2024
149edf2
Merge branch 'main' into IMN-145-implement-remaining-tests-in-catalog…
taglioni-r Jan 22, 2024
70e22b8
Merge branch 'refactor-and-bug-fixing-in-catalog-process' into IMN-14…
taglioni-r Jan 22, 2024
2721cd0
refactor string ids
taglioni-r Jan 22, 2024
c99a5ae
Improve check on version number
taglioni-r Jan 22, 2024
b0ef45b
Edit test name
taglioni-r Jan 23, 2024
23e82ee
Fix business logic
taglioni-r Jan 24, 2024
0eb90fe
Fix tests and add coverage
taglioni-r Jan 24, 2024
55fee87
Add error in mapper
taglioni-r Jan 24, 2024
2e84b4f
Update business logic
taglioni-r Jan 24, 2024
cab9a4d
Update tests
taglioni-r Jan 24, 2024
74c938d
Add check in business logic
taglioni-r Jan 25, 2024
9d70bea
Fix previous tests
taglioni-r Jan 25, 2024
ac01572
Add new tests
taglioni-r Jan 25, 2024
fdd55d2
Add error in mapper
taglioni-r Jan 25, 2024
e044962
Fix business logic
taglioni-r Jan 26, 2024
1d1f57b
Fix previous tests
taglioni-r Jan 26, 2024
16d1692
Add test coverage
taglioni-r Jan 26, 2024
0afbc38
Fix business logic
taglioni-r Jan 26, 2024
6dd6a9f
Add test
taglioni-r Jan 26, 2024
6453f9d
Fix test
taglioni-r Jan 26, 2024
7e4b54b
Refactor
taglioni-r Jan 26, 2024
ec16e8f
Refactor
taglioni-r Jan 26, 2024
01a3934
Minor fix
taglioni-r Jan 29, 2024
3decd5b
Merge branch 'IMN-207_add-name-check-on-eservice-update' into IMN-195…
taglioni-r Jan 29, 2024
fd803aa
Merge branch 'IMN-195_fix-document-upload-based-on-descriptor-state' …
taglioni-r Jan 29, 2024
d80c3e9
Merge branch 'IMN-209_fix-document-delete-based-on-descriptor-state' …
taglioni-r Jan 29, 2024
34fa7c1
Add error in mapper
taglioni-r Jan 29, 2024
087d815
Minor fixes
taglioni-r Jan 29, 2024
8b36438
Merge branch 'IMN-209_fix-document-delete-based-on-descriptor-state' …
taglioni-r Jan 29, 2024
2985836
Fix
taglioni-r Jan 29, 2024
a207156
Fix
taglioni-r Jan 29, 2024
c5b63af
Fix
taglioni-r Jan 29, 2024
aa1699c
Merge branch 'IMN-207_add-name-check-on-eservice-update' into IMN-195…
taglioni-r Jan 29, 2024
0bb951c
Merge branch 'IMN-195_fix-document-upload-based-on-descriptor-state' …
taglioni-r Jan 29, 2024
d568d3f
Fix error title
taglioni-r Jan 31, 2024
c65501f
Fix business logic
taglioni-r Jan 31, 2024
a7884ae
Fix tests
taglioni-r Jan 31, 2024
5b8a70b
Add test coverage
taglioni-r Jan 31, 2024
e4e9606
Change status code
taglioni-r Jan 31, 2024
3e3ff7d
Fix
taglioni-r Jan 31, 2024
14b0e1c
Merge branch 'IMN-209_fix-document-delete-based-on-descriptor-state' …
taglioni-r Jan 31, 2024
b53c504
Fix
taglioni-r Jan 31, 2024
58db97d
Merge branch 'IMN-211_add-check-for-duplicate-interface' into IMN-213…
taglioni-r Jan 31, 2024
a7016bd
Fix case where the update doesn't change the name
taglioni-r Feb 2, 2024
c59cdd7
Merge branch 'IMN-145-implement-remaining-tests-in-catalog-process' i…
taglioni-r Feb 2, 2024
306cc90
Refactor
taglioni-r Feb 5, 2024
5c1cfb3
Improve timing in tests
taglioni-r Feb 5, 2024
2618c67
Refactor
taglioni-r Feb 5, 2024
7f03293
Merge branch 'main' into refactor-and-bug-fixing-in-catalog-process
taglioni-r Feb 7, 2024
ff07c48
Merge branch 'refactor-and-bug-fixing-in-catalog-process' into IMN-14…
taglioni-r Feb 7, 2024
3ab8534
Merge branch 'IMN-145-implement-remaining-tests-in-catalog-process' i…
taglioni-r Feb 7, 2024
4b0e795
Fix after merge
taglioni-r Feb 7, 2024
544256b
Merge branch 'IMN-200_fix-name-of-cloned-eservice' into IMN-207_add-n…
taglioni-r Feb 7, 2024
8c22f22
Improve logic to avoid not needed queries
taglioni-r Feb 12, 2024
dbc0a2b
Merge branch 'main' into refactor-and-bug-fixing-in-catalog-process
taglioni-r Feb 12, 2024
fffc812
Merge branch 'main' into refactor-and-bug-fixing-in-catalog-process
taglioni-r Feb 13, 2024
d66dd39
Merge branch 'refactor-and-bug-fixing-in-catalog-process' into IMN-14…
taglioni-r Feb 13, 2024
44ded25
Refactor and fix id
taglioni-r Feb 13, 2024
e62e021
Merge branch 'IMN-145-implement-remaining-tests-in-catalog-process' i…
taglioni-r Feb 13, 2024
a30937b
Merge branch 'IMN-200_fix-name-of-cloned-eservice' into IMN-207_add-n…
taglioni-r Feb 13, 2024
dfc10f0
Merge branch 'main' into refactor-and-bug-fixing-in-catalog-process
taglioni-r Feb 13, 2024
7c2a4e7
Merge branch 'refactor-and-bug-fixing-in-catalog-process' into IMN-14…
taglioni-r Feb 13, 2024
33d126a
Merge branch 'IMN-145-implement-remaining-tests-in-catalog-process' i…
taglioni-r Feb 13, 2024
c9f9ea1
Merge branch 'IMN-200_fix-name-of-cloned-eservice' into IMN-207_add-n…
taglioni-r Feb 13, 2024
dc34445
Merge branch 'IMN-207_add-name-check-on-eservice-update' into IMN-195…
taglioni-r Feb 13, 2024
7cb6cd8
Merge branch 'IMN-195_fix-document-upload-based-on-descriptor-state' …
taglioni-r Feb 13, 2024
881cc3a
Merge branch 'IMN-209_fix-document-delete-based-on-descriptor-state' …
taglioni-r Feb 13, 2024
4c99a20
Merge branch 'IMN-211_add-check-for-duplicate-interface' into IMN-213…
taglioni-r Feb 13, 2024
9a3b7bc
Merge branch 'main' into IMN-213_fix-document-update-based-on-descrip…
taglioni-r Feb 13, 2024
6bf00e6
Fix ids
taglioni-r Feb 13, 2024
2b16d43
Merge branch 'main' into IMN-213_fix-document-update-based-on-descrip…
taglioni-r Feb 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions packages/catalog-process/src/model/domain/errors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ export const errorCodes = {
draftDescriptorAlreadyExists: "0008",
eserviceCannotBeUpdatedOrDeleted: "0009",
eServiceDuplicate: "0010",
interfaceAlreadyExists: "0011",
};

export type ErrorCodes = keyof typeof errorCodes;
Expand Down Expand Up @@ -126,3 +127,13 @@ export function invalidDescriptorVersion(
title: "Version is not a valid descriptor version",
});
}

export function interfaceAlreadyExists(
descriptorId: DescriptorId
): ApiError<ErrorCodes> {
return new ApiError({
detail: `Descriptor ${descriptorId} already contains an interface`,
code: "interfaceAlreadyExists",
title: "Descriptor already contains an interface",
});
}
99 changes: 68 additions & 31 deletions packages/catalog-process/src/services/catalogService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@ import {
notValidDescriptor,
eServiceNotFound,
eServiceDescriptorWithoutInterface,
interfaceAlreadyExists,
} from "../model/domain/errors.js";
import { ReadModelService } from "./readModelService.js";

Expand Down Expand Up @@ -218,7 +219,17 @@ export function catalogServiceBuilder(
const eService = await readModelService.getEServiceById(eServiceId);

await repository.createEvent(
updateEserviceLogic({ eService, eServiceId, authData, eServiceSeed })
updateEserviceLogic({
eService,
eServiceId,
authData,
eServiceSeed,
eServiceWithSameName:
await readModelService.getEServiceByNameAndProducerId({
name: eServiceSeed.name,
producerId: authData.organizationId,
}),
})
);
},

Expand Down Expand Up @@ -432,6 +443,8 @@ export function catalogServiceBuilder(
authData,
copyFile: fileManager.copy,
eService,
getEServiceByNameAndProducerId:
readModelService.getEServiceByNameAndProducerId,
});

await repository.createEvent(event);
Expand Down Expand Up @@ -494,11 +507,13 @@ export function updateEserviceLogic({
eServiceId,
authData,
eServiceSeed,
eServiceWithSameName,
}: {
eService: WithMetadata<EService> | undefined;
eServiceId: string;
authData: AuthData;
eServiceSeed: ApiEServiceSeed;
eServiceWithSameName: WithMetadata<EService> | undefined;
}): CreateEvent<EServiceEvent> {
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);
Expand All @@ -513,6 +528,10 @@ export function updateEserviceLogic({
throw eServiceCannotBeUpdated(eServiceId);
}

if (eServiceWithSameName) {
throw eServiceDuplicate(eServiceSeed.name);
}

const updatedEService: EService = {
...eService.data,
description: eServiceSeed.description,
Expand Down Expand Up @@ -563,11 +582,14 @@ export function uploadDocumentLogic({
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);

const descriptor = eService.data.descriptors.find(
(d: Descriptor) => d.id === descriptorId
);
if (descriptor === undefined) {
throw eServiceDescriptorNotFound(eServiceId, descriptorId);
const descriptor = retrieveDescriptor(descriptorId, eService);

if (descriptor.state !== descriptorState.draft) {
throw notValidDescriptor(descriptor.id, descriptor.state);
}

if (document.kind === "INTERFACE" && descriptor.interface) {
throw interfaceAlreadyExists(descriptor.id);
}

return toCreateEventEServiceDocumentAdded(
Expand Down Expand Up @@ -608,13 +630,15 @@ export async function deleteDocumentLogic({
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);

const descriptor = eService.data.descriptors.find(
(d: Descriptor) => d.id === descriptorId
);
const descriptor = retrieveDescriptor(descriptorId, eService);

const document = (
descriptor ? [...descriptor.docs, descriptor.interface] : []
).find((doc) => doc != null && doc.id === documentId);
if (descriptor.state !== descriptorState.draft) {
throw notValidDescriptor(descriptor.id, descriptor.state);
}

const document = [...descriptor.docs, descriptor.interface].find(
(doc) => doc != null && doc.id === documentId
);
if (document === undefined) {
throw eServiceDocumentNotFound(eServiceId, descriptorId, documentId);
}
Expand Down Expand Up @@ -647,11 +671,10 @@ export async function updateDocumentLogic({
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);

const descriptor = eService.data.descriptors.find(
(d: Descriptor) => d.id === descriptorId
);
if (descriptor === undefined) {
throw eServiceDescriptorNotFound(eServiceId, descriptorId);
const descriptor = retrieveDescriptor(descriptorId, eService);

if (descriptor.state !== descriptorState.draft) {
throw notValidDescriptor(descriptor.id, descriptor.state);
}

const document = (
Expand Down Expand Up @@ -752,13 +775,10 @@ export async function deleteDraftDescriptorLogic({
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);

const descriptor = eService.data.descriptors.find(
(d: Descriptor) =>
d.id === descriptorId && d.state === descriptorState.draft
);
const descriptor = retrieveDescriptor(descriptorId, eService);

if (descriptor === undefined) {
throw eServiceDescriptorNotFound(eServiceId, descriptorId);
if (descriptor.state !== descriptorState.draft) {
throw notValidDescriptor(descriptorId, descriptor.state.toString());
}

const interfacePath = descriptor.docs.find(
Expand Down Expand Up @@ -797,12 +817,7 @@ export function updateDescriptorLogic({
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);

const descriptor = eService.data.descriptors.find(
(d: Descriptor) => d.id === descriptorId
);
if (descriptor === undefined) {
throw eServiceDescriptorNotFound(eServiceId, descriptorId);
}
const descriptor = retrieveDescriptor(descriptorId, eService);

if (descriptor.state !== descriptorState.draft) {
throw notValidDescriptor(descriptorId, descriptor.state.toString());
Expand Down Expand Up @@ -989,6 +1004,7 @@ export async function cloneDescriptorLogic({
authData,
copyFile,
eService,
getEServiceByNameAndProducerId,
}: {
eServiceId: string;
descriptorId: DescriptorId;
Expand All @@ -1001,12 +1017,33 @@ export async function cloneDescriptorLogic({
name: string
) => Promise<string>;
eService: WithMetadata<EService> | undefined;
getEServiceByNameAndProducerId: ({
name,
producerId,
}: {
name: string;
producerId: string;
}) => Promise<WithMetadata<EService> | undefined>;
}): Promise<{ eService: EService; event: CreateEvent<EServiceEvent> }> {
assertEServiceExist(eServiceId, eService);
assertRequesterAllowed(eService.data.producerId, authData.organizationId);

const descriptor = retrieveDescriptor(descriptorId, eService);
const currentDate = new Date();
const formattedDateAndTime = `${currentDate.toLocaleDateString(
"it-IT"
)} ${currentDate.toLocaleTimeString("it-IT")}`;
const clonedEServiceName = `${eService.data.name} - clone - ${formattedDateAndTime}`;

if (
await getEServiceByNameAndProducerId({
name: clonedEServiceName,
producerId: authData.organizationId,
})
) {
throw eServiceDuplicate(clonedEServiceName);
}

const descriptor = retrieveDescriptor(descriptorId, eService);
const sourceDocument = descriptor.docs[0];
const clonedDocumentId = uuidv4();

Expand Down Expand Up @@ -1060,7 +1097,7 @@ export async function cloneDescriptorLogic({
const draftCatalogItem: EService = {
id: uuidv4(),
producerId: eService.data.producerId,
name: `${eService.data.name} - clone`,
name: clonedEServiceName,
description: eService.data.description,
technology: eService.data.technology,
attributes: eService.data.attributes,
Expand Down
4 changes: 2 additions & 2 deletions packages/catalog-process/src/services/readModelService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -320,7 +320,7 @@ export function readModelServiceBuilder(
"data.producerId": { $in: producersIds },
}),
...ReadModelRepository.arrayToFilter(states, {
"data.state": { $elemMatch: { state: { $in: states } } },
"data.state": { $in: states },
}),
} satisfies ReadModelFilter<Agreement>,
},
Expand All @@ -334,7 +334,7 @@ export function readModelServiceBuilder(
},
];
const data = await agreements.aggregate(aggregationPipeline).toArray();
const result = z.array(Agreement).safeParse(data);
const result = z.array(Agreement).safeParse(data.map((a) => a.data));

if (!result.success) {
logger.error(
Expand Down
12 changes: 11 additions & 1 deletion packages/catalog-process/src/utilities/errorMappers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ export const deleteEServiceErrorMapper = (
match(error.code)
.with("eServiceNotFound", () => HTTP_STATUS_NOT_FOUND)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.with("eserviceCannotBeUpdatedOrDeleted", () => HTTP_STATUS_BAD_REQUEST)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);

export const documentCreateErrorMapper = (
Expand All @@ -47,6 +48,11 @@ export const documentCreateErrorMapper = (
"eServiceDescriptorNotFound",
() => HTTP_STATUS_NOT_FOUND
)
.with(
"notValidDescriptor",
"interfaceAlreadyExists",
() => HTTP_STATUS_BAD_REQUEST
)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);

Expand All @@ -56,9 +62,11 @@ export const documentUpdateDeleteErrorMapper = (
match(error.code)
.with(
"eServiceNotFound",
"eServiceDescriptorNotFound",
"eServiceDocumentNotFound",
() => HTTP_STATUS_NOT_FOUND
)
.with("notValidDescriptor", () => HTTP_STATUS_BAD_REQUEST)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);

Expand All @@ -80,6 +88,7 @@ export const deleteDraftDescriptorErrorMapper = (
"eServiceDescriptorNotFound",
() => HTTP_STATUS_NOT_FOUND
)
.with("notValidDescriptor", () => HTTP_STATUS_BAD_REQUEST)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);

Expand All @@ -105,6 +114,7 @@ export const publishDescriptorErrorMapper = (
"eServiceDescriptorNotFound",
() => HTTP_STATUS_NOT_FOUND
)
.with("notValidDescriptor", () => HTTP_STATUS_BAD_REQUEST)
.with("eServiceDescriptorWithoutInterface", () => HTTP_STATUS_BAD_REQUEST)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);
Expand Down Expand Up @@ -144,6 +154,7 @@ export const cloneEServiceByDescriptorErrorMapper = (
"eServiceDescriptorNotFound",
() => HTTP_STATUS_NOT_FOUND
)
.with("eServiceDuplicate", () => HTTP_STATUS_CONFLICT)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);

Expand All @@ -156,6 +167,5 @@ export const archiveDescriptorErrorMapper = (
"eServiceDescriptorNotFound",
() => HTTP_STATUS_NOT_FOUND
)
.with("notValidDescriptor", () => HTTP_STATUS_BAD_REQUEST)
.with("operationForbidden", () => HTTP_STATUS_FORBIDDEN)
.otherwise(() => HTTP_STATUS_INTERNAL_SERVER_ERROR);
2 changes: 1 addition & 1 deletion packages/catalog-process/src/utilities/versionGenerator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ export const nextDescriptorVersion = (eservice: EService): string => {
}

return currentVersionNumber.data > max ? currentVersionNumber.data : max;
}, 0);
}, 1);

return currentVersion.toString();
};
Loading
Loading