From ab4fac8e01ea993faa0e003bd12969e6293dfda1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFs=20Mansot?= <26844641+devfull@users.noreply.github.com> Date: Fri, 29 Sep 2023 15:36:31 +0200 Subject: [PATCH] link an anchor to folder when requesting a new job --- .../notary/OfficeFolderAnchorsController.ts | 53 +++++++++++++++++-- .../repositories/OfficeFoldersRepository.ts | 2 + 2 files changed, 51 insertions(+), 4 deletions(-) diff --git a/src/app/api/notary/OfficeFolderAnchorsController.ts b/src/app/api/notary/OfficeFolderAnchorsController.ts index 29f9e0ea..bc14dadb 100644 --- a/src/app/api/notary/OfficeFolderAnchorsController.ts +++ b/src/app/api/notary/OfficeFolderAnchorsController.ts @@ -5,15 +5,35 @@ import { Service } from "typedi"; import { OfficeFolder } from "le-coffre-resources/dist/Notary"; import { getFolderHashes } from "@Common/optics/notary"; import OfficeFoldersService from "@Services/notary/OfficeFoldersService/OfficeFoldersService"; +import OfficeFolderAnchorsRepository from "@Repositories/OfficeFolderAnchorsRepository"; import SecureService from "@Services/common/SecureService/SecureService"; import authHandler from "@App/middlewares/AuthHandler"; import ruleHandler from "@App/middlewares/RulesHandler"; import folderHandler from "@App/middlewares/OfficeMembershipHandlers/FolderHandler"; +import OfficeFolderAnchor from "le-coffre-resources/dist/Notary/OfficeFolderAnchor"; +const hydrateOfficeFolderAnchor = (data: any): OfficeFolderAnchor => + OfficeFolderAnchor.hydrate( + { + hash_sources: data.hash_sources, + root_hash: data.root_hash, + + blockchain: data.transactions[0].blockchain, + status: data.transactions[0].status, + + anchor_nb_try: data.transactions[0].anchor_nb_try, + tx_id: data.transactions[0].tx_id.toString(), + tx_link: data.transactions[0].tx_link, + tx_hash: data.transactions[0].tx_hash, + + anchored_at: data.transactions[0].anchoring_timestamp, + }, + { strategy: "excludeAll" }, + ); @Controller() @Service() export default class OfficeFoldersController extends ApiController { - constructor(private secureService: SecureService, private officeFoldersService: OfficeFoldersService) { + constructor(private secureService: SecureService, private officeFolderAnchorsRepository: OfficeFolderAnchorsRepository, private officeFoldersService: OfficeFoldersService) { super(); } @@ -83,16 +103,30 @@ export default class OfficeFoldersController extends ApiController { files: true, }, }, + folder_anchor: true, }; - const officeFolderFound = await this.officeFoldersService.getByUid(uid, query); + const officeFolderFound: any = await this.officeFoldersService.getByUid(uid, query); if (!officeFolderFound) { this.httpNotFoundRequest(response, "Office folder not found"); return; } + const officeFolderAnchorFound = OfficeFolderAnchor.hydrate(officeFolderFound.folder_anchor, { + strategy: "excludeAll", + }); + + if (officeFolderAnchorFound) { + this.httpBadRequest(response, { + error: "Office folder already anchored", + folder_anchor: officeFolderAnchorFound, + }); + return; + } + const officeFolder = OfficeFolder.hydrate(officeFolderFound, { strategy: "excludeAll" }); + const folderHashes = getFolderHashes(officeFolder); if (folderHashes.length === 0) { @@ -101,9 +135,20 @@ export default class OfficeFoldersController extends ApiController { } const sortedHashes = [...folderHashes].sort(); - const anchor = await this.secureService.anchor(sortedHashes); + const data = await this.secureService.anchor(sortedHashes); - this.httpSuccess(response, anchor); + const officeFolderAnchor = hydrateOfficeFolderAnchor(data); + + const newOfficeFolderAnchor = await this.officeFolderAnchorsRepository.create( + officeFolderAnchor + ); + + await this.officeFoldersService.update( + uid, + OfficeFolder.hydrate({ uid: uid, folder_anchor: newOfficeFolderAnchor }, { strategy: "excludeAll" }), + ); + + this.httpSuccess(response, officeFolderAnchor); } catch (error) { this.httpInternalError(response, error); return; diff --git a/src/common/repositories/OfficeFoldersRepository.ts b/src/common/repositories/OfficeFoldersRepository.ts index 8eb5c7c9..5d591906 100644 --- a/src/common/repositories/OfficeFoldersRepository.ts +++ b/src/common/repositories/OfficeFoldersRepository.ts @@ -84,6 +84,7 @@ export default class OfficeFoldersRepository extends BaseRepository { uid: document.uid!, })), }, + folder_anchor_uid: officeFolder.folder_anchor?.uid, }, }; @@ -93,6 +94,7 @@ export default class OfficeFoldersRepository extends BaseRepository { stakeholders: true, customers: true, documents: true, + folder_anchor: true, }, }); }