Merge branch 'dev' into preprod
This commit is contained in:
commit
f5ad1821c7
@ -47,6 +47,7 @@
|
|||||||
"@prisma/client": "^4.11.0",
|
"@prisma/client": "^4.11.0",
|
||||||
"@sentry/node": "^7.91.0",
|
"@sentry/node": "^7.91.0",
|
||||||
"adm-zip": "^0.5.10",
|
"adm-zip": "^0.5.10",
|
||||||
|
"aws-sdk": "^2.1556.0",
|
||||||
"axios": "^1.6.2",
|
"axios": "^1.6.2",
|
||||||
"bcrypt": "^5.1.1",
|
"bcrypt": "^5.1.1",
|
||||||
"class-transformer": "^0.5.1",
|
"class-transformer": "^0.5.1",
|
||||||
@ -58,7 +59,7 @@
|
|||||||
"file-type-checker": "^1.0.8",
|
"file-type-checker": "^1.0.8",
|
||||||
"fp-ts": "^2.16.1",
|
"fp-ts": "^2.16.1",
|
||||||
"jsonwebtoken": "^9.0.0",
|
"jsonwebtoken": "^9.0.0",
|
||||||
"le-coffre-resources": "git@github.com:smart-chain-fr/leCoffre-resources.git#v2.108",
|
"le-coffre-resources": "git@github.com:smart-chain-fr/leCoffre-resources.git#v2.119",
|
||||||
"module-alias": "^2.2.2",
|
"module-alias": "^2.2.2",
|
||||||
"monocle-ts": "^2.3.13",
|
"monocle-ts": "^2.3.13",
|
||||||
"multer": "^1.4.5-lts.1",
|
"multer": "^1.4.5-lts.1",
|
||||||
|
@ -116,12 +116,19 @@ export default class OfficeRolesController extends ApiController {
|
|||||||
if (req.body.rules) {
|
if (req.body.rules) {
|
||||||
const allRules = await this.rulesService.get({
|
const allRules = await this.rulesService.get({
|
||||||
where: {
|
where: {
|
||||||
namespace: "notary",
|
OR: [
|
||||||
|
{
|
||||||
|
namespace: "notary",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
namespace: "collaborator",
|
||||||
|
},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
req.body.rules = req.body.rules.filter((rule: any) => {
|
req.body.rules = req.body.rules.filter((rule: any) => {
|
||||||
const ruleFound = allRules.find((r) => r.uid === rule.uid && r.namespace === "notary");
|
const ruleFound = allRules.find((r) => r.uid === rule.uid && (r.namespace === "notary" || r.namespace === "collaborator"));
|
||||||
return ruleFound;
|
return ruleFound;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
43
src/app/api/customer/OfficeRibController.ts
Normal file
43
src/app/api/customer/OfficeRibController.ts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import { Response, Request } from "express";
|
||||||
|
import { Controller, Get } from "@ControllerPattern/index";
|
||||||
|
import ApiController from "@Common/system/controller-pattern/ApiController";
|
||||||
|
|
||||||
|
import { Service } from "typedi";
|
||||||
|
import OfficerRibService from "@Services/common/OfficeRibService/OfficeRibService";
|
||||||
|
import authHandler from "@App/middlewares/AuthHandler";
|
||||||
|
import OfficesService from "@Services/customer/OfficesService/OfficesService";
|
||||||
|
|
||||||
|
@Controller()
|
||||||
|
@Service()
|
||||||
|
export default class OfficeRibController extends ApiController {
|
||||||
|
constructor(private officeRibService: OfficerRibService, private officesService: OfficesService) {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get("/api/v1/customer/office/:uid/rib", [authHandler])
|
||||||
|
protected async getRibStream(req: Request, response: Response) {
|
||||||
|
const officeId = req.params["uid"];
|
||||||
|
if (!officeId) throw new Error("No officeId provided");
|
||||||
|
|
||||||
|
const office = await this.officesService.getByUid(officeId, { address: true });
|
||||||
|
|
||||||
|
if (!office) {
|
||||||
|
this.httpNotFoundRequest(response, "Office not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const fileName = office.rib_name;
|
||||||
|
if (!fileName) {
|
||||||
|
this.httpNotFoundRequest(response, "No file found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const file = await this.officeRibService.getByUid(officeId, fileName!);
|
||||||
|
response.attachment(fileName!);
|
||||||
|
response.send(file.Body);
|
||||||
|
} catch (error) {
|
||||||
|
this.httpInternalError(response, error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
123
src/app/api/notary/OfficeRibController.ts
Normal file
123
src/app/api/notary/OfficeRibController.ts
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
import { Response, Request } from "express";
|
||||||
|
import { Controller, Delete, Get, Post } from "@ControllerPattern/index";
|
||||||
|
import ApiController from "@Common/system/controller-pattern/ApiController";
|
||||||
|
|
||||||
|
import { Service } from "typedi";
|
||||||
|
import OfficerRibService from "@Services/common/OfficeRibService/OfficeRibService";
|
||||||
|
import authHandler from "@App/middlewares/AuthHandler";
|
||||||
|
import OfficesService from "@Services/notary/OfficesService/OfficesService";
|
||||||
|
import { Office as OfficeResource } from "le-coffre-resources/dist/Notary";
|
||||||
|
|
||||||
|
@Controller()
|
||||||
|
@Service()
|
||||||
|
export default class OfficeRibController extends ApiController {
|
||||||
|
constructor(private officeRibService: OfficerRibService, private officesService: OfficesService) {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get("/api/v1/notary/office/rib", [authHandler])
|
||||||
|
protected async getRibStream(req: Request, response: Response) {
|
||||||
|
const officeId: string = req.body.user.office_Id;
|
||||||
|
if (!officeId) throw new Error("No officeId provided");
|
||||||
|
|
||||||
|
const office = await this.officesService.getByUid(officeId, { address: true });
|
||||||
|
|
||||||
|
if (!office) {
|
||||||
|
this.httpNotFoundRequest(response, "Office not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const fileName = office.rib_name;
|
||||||
|
if (!fileName) {
|
||||||
|
this.httpNotFoundRequest(response, "No file found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const file = await this.officeRibService.getByUid(officeId, fileName!);
|
||||||
|
response.attachment(fileName!);
|
||||||
|
response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
|
||||||
|
response.send(file.Body);
|
||||||
|
} catch (error) {
|
||||||
|
this.httpInternalError(response, error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post("/api/v1/notary/office/rib", [authHandler])
|
||||||
|
protected async post(req: Request, response: Response) {
|
||||||
|
try {
|
||||||
|
const officeId: string = req.body.user.office_Id;
|
||||||
|
if (!req.file) throw new Error("No file provided");
|
||||||
|
if (!officeId) throw new Error("No officeId provided");
|
||||||
|
|
||||||
|
const office = await this.officesService.getByUid(officeId, { address: true });
|
||||||
|
|
||||||
|
if (!office) {
|
||||||
|
this.httpNotFoundRequest(response, "office not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const fileUrl = await this.officeRibService.createOrUpdate(officeId, req.file);
|
||||||
|
|
||||||
|
if (!fileUrl || !req.file.originalname) throw new Error("Error while uploading file");
|
||||||
|
|
||||||
|
office.rib_url = fileUrl;
|
||||||
|
office.rib_name = req.file.originalname;
|
||||||
|
|
||||||
|
const officeEntity = OfficeResource.hydrate<OfficeResource>(office, {
|
||||||
|
strategy: "excludeAll",
|
||||||
|
});
|
||||||
|
|
||||||
|
//call service to get prisma entity
|
||||||
|
const officeEntityUpdated = await this.officesService.update(officeId, officeEntity);
|
||||||
|
//Hydrate ressource with prisma entity
|
||||||
|
const officeUpdated = OfficeResource.hydrate<OfficeResource>(officeEntityUpdated, {
|
||||||
|
strategy: "excludeAll",
|
||||||
|
});
|
||||||
|
|
||||||
|
//success
|
||||||
|
this.httpCreated(response, officeUpdated);
|
||||||
|
} catch (error) {
|
||||||
|
this.httpInternalError(response, error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete("/api/v1/notary/office/rib", [authHandler])
|
||||||
|
protected async delete(req: Request, response: Response) {
|
||||||
|
try {
|
||||||
|
const officeId: string = req.body.user.office_Id;
|
||||||
|
if (!officeId) throw new Error("No officeId provided");
|
||||||
|
|
||||||
|
const office = await this.officesService.getByUid(officeId, { address: true });
|
||||||
|
|
||||||
|
if (!office) {
|
||||||
|
this.httpNotFoundRequest(response, "office not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const fileName = office.rib_name;
|
||||||
|
|
||||||
|
await this.officeRibService.delete(officeId, fileName!);
|
||||||
|
|
||||||
|
office.rib_url = null;
|
||||||
|
office.rib_name = null;
|
||||||
|
|
||||||
|
const officeEntity = OfficeResource.hydrate<OfficeResource>(office, {
|
||||||
|
strategy: "excludeAll",
|
||||||
|
});
|
||||||
|
|
||||||
|
//call service to get prisma entity
|
||||||
|
const officeEntityUpdated = await this.officesService.update(officeId, officeEntity);
|
||||||
|
//Hydrate ressource with prisma entity
|
||||||
|
const officeUpdated = OfficeResource.hydrate<OfficeResource>(officeEntityUpdated, {
|
||||||
|
strategy: "excludeAll",
|
||||||
|
});
|
||||||
|
|
||||||
|
//success
|
||||||
|
this.httpCreated(response, officeUpdated);
|
||||||
|
} catch (error) {
|
||||||
|
this.httpInternalError(response, error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -7,6 +7,7 @@ import { Offices, Prisma } from "@prisma/client";
|
|||||||
import { Office as OfficeResource } from "le-coffre-resources/dist/Notary";
|
import { Office as OfficeResource } from "le-coffre-resources/dist/Notary";
|
||||||
import ruleHandler from "@App/middlewares/RulesHandler";
|
import ruleHandler from "@App/middlewares/RulesHandler";
|
||||||
import authHandler from "@App/middlewares/AuthHandler";
|
import authHandler from "@App/middlewares/AuthHandler";
|
||||||
|
import uuidMatcher from "@App/uuidMatcher";
|
||||||
|
|
||||||
@Controller()
|
@Controller()
|
||||||
@Service()
|
@Service()
|
||||||
@ -49,8 +50,9 @@ export default class OfficesController extends ApiController {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Get a specific office by uid
|
* @description Get a specific office by uid
|
||||||
|
* `/:id(${uuidMatcher})`
|
||||||
*/
|
*/
|
||||||
@Get("/api/v1/notary/offices/:uid", [authHandler, ruleHandler])
|
@Get(`/api/v1/notary/offices/:uid(${uuidMatcher})`, [authHandler, ruleHandler])
|
||||||
protected async getOneByUid(req: Request, response: Response) {
|
protected async getOneByUid(req: Request, response: Response) {
|
||||||
try {
|
try {
|
||||||
const uid = req.params["uid"];
|
const uid = req.params["uid"];
|
||||||
@ -69,6 +71,7 @@ export default class OfficesController extends ApiController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const officeEntity = await this.officesService.getByUid(uid, query);
|
const officeEntity = await this.officesService.getByUid(uid, query);
|
||||||
|
|
||||||
|
|
||||||
if (!officeEntity) {
|
if (!officeEntity) {
|
||||||
this.httpNotFoundRequest(response, "office not found");
|
this.httpNotFoundRequest(response, "office not found");
|
||||||
@ -77,6 +80,8 @@ export default class OfficesController extends ApiController {
|
|||||||
|
|
||||||
//Hydrate ressource with prisma entity
|
//Hydrate ressource with prisma entity
|
||||||
const office = OfficeResource.hydrate<OfficeResource>(officeEntity, { strategy: "excludeAll" });
|
const office = OfficeResource.hydrate<OfficeResource>(officeEntity, { strategy: "excludeAll" });
|
||||||
|
|
||||||
|
|
||||||
//success
|
//success
|
||||||
this.httpSuccess(response, office);
|
this.httpSuccess(response, office);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
@ -46,6 +46,8 @@ import DocumentControllerId360 from "./api/id360/DocumentController";
|
|||||||
import CustomerControllerId360 from "./api/id360/CustomerController";
|
import CustomerControllerId360 from "./api/id360/CustomerController";
|
||||||
import UserNotificationController from "./api/notary/UserNotificationController";
|
import UserNotificationController from "./api/notary/UserNotificationController";
|
||||||
import AuthController from "./api/customer/AuthController";
|
import AuthController from "./api/customer/AuthController";
|
||||||
|
import NotaryOfficeRibController from "./api/notary/OfficeRibController";
|
||||||
|
import CustomerOfficeRibController from "./api/customer/OfficeRibController";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description This allow to declare all controllers used in the application
|
* @description This allow to declare all controllers used in the application
|
||||||
@ -100,5 +102,7 @@ export default {
|
|||||||
Container.get(DocumentControllerId360);
|
Container.get(DocumentControllerId360);
|
||||||
Container.get(CustomerControllerId360);
|
Container.get(CustomerControllerId360);
|
||||||
Container.get(AuthController);
|
Container.get(AuthController);
|
||||||
|
Container.get(NotaryOfficeRibController);
|
||||||
|
Container.get(CustomerOfficeRibController);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
2
src/app/uuidMatcher.ts
Normal file
2
src/app/uuidMatcher.ts
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
const uuidMatcher = "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[89ab][0-9a-f]{3}-[0-9a-f]{12}";
|
||||||
|
export default uuidMatcher;
|
@ -130,6 +130,18 @@ export class BackendVariables {
|
|||||||
@IsNotEmpty()
|
@IsNotEmpty()
|
||||||
public readonly SMS_FACTOR_TOKEN!: string;
|
public readonly SMS_FACTOR_TOKEN!: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
public readonly SCW_ACCESS_KEY_ID!: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
public readonly SCW_ACCESS_KEY_SECRET!: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
public readonly SCW_BUCKET_ENDPOINT!: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
public readonly SCW_BUCKET_NAME!: string;
|
||||||
|
|
||||||
public constructor() {
|
public constructor() {
|
||||||
dotenv.config();
|
dotenv.config();
|
||||||
this.DATABASE_PORT = process.env["DATABASE_PORT"]!;
|
this.DATABASE_PORT = process.env["DATABASE_PORT"]!;
|
||||||
@ -174,6 +186,10 @@ export class BackendVariables {
|
|||||||
this.OVH_CONSUMER_KEY = process.env["OVH_CONSUMER_KEY"]!;
|
this.OVH_CONSUMER_KEY = process.env["OVH_CONSUMER_KEY"]!;
|
||||||
this.OVH_SMS_SERVICE_NAME = process.env["OVH_SMS_SERVICE_NAME"]!;
|
this.OVH_SMS_SERVICE_NAME = process.env["OVH_SMS_SERVICE_NAME"]!;
|
||||||
this.SMS_FACTOR_TOKEN = process.env["SMS_FACTOR_TOKEN"]!;
|
this.SMS_FACTOR_TOKEN = process.env["SMS_FACTOR_TOKEN"]!;
|
||||||
|
this.SCW_ACCESS_KEY_ID = process.env["SCW_ACCESS_KEY_ID"]!;
|
||||||
|
this.SCW_ACCESS_KEY_SECRET = process.env["SCW_ACCESS_KEY_SECRET"]!;
|
||||||
|
this.SCW_BUCKET_ENDPOINT = process.env["SCW_BUCKET_ENDPOINT"]!;
|
||||||
|
this.SCW_BUCKET_NAME = process.env["SCW_BUCKET_NAME"]!;
|
||||||
}
|
}
|
||||||
public async validate(groups?: string[]) {
|
public async validate(groups?: string[]) {
|
||||||
const validationOptions = groups ? { groups } : undefined;
|
const validationOptions = groups ? { groups } : undefined;
|
||||||
|
@ -0,0 +1,2 @@
|
|||||||
|
-- AlterTable
|
||||||
|
ALTER TABLE "offices" ADD COLUMN "rib_url" VARCHAR(255) DEFAULT '';
|
@ -0,0 +1,2 @@
|
|||||||
|
-- AlterTable
|
||||||
|
ALTER TABLE "offices" ALTER COLUMN "rib_url" DROP DEFAULT;
|
@ -0,0 +1,2 @@
|
|||||||
|
-- AlterTable
|
||||||
|
ALTER TABLE "offices" ADD COLUMN "rib_name" VARCHAR(255);
|
@ -92,6 +92,8 @@ model Offices {
|
|||||||
created_at DateTime? @default(now())
|
created_at DateTime? @default(now())
|
||||||
updated_at DateTime? @updatedAt
|
updated_at DateTime? @updatedAt
|
||||||
checked_at DateTime?
|
checked_at DateTime?
|
||||||
|
rib_url String? @db.VarChar(255)
|
||||||
|
rib_name String? @db.VarChar(255)
|
||||||
deed_types DeedTypes[]
|
deed_types DeedTypes[]
|
||||||
users Users[]
|
users Users[]
|
||||||
office_folders OfficeFolders[]
|
office_folders OfficeFolders[]
|
||||||
|
@ -1264,7 +1264,7 @@ export default async function main() {
|
|||||||
const documentTypeCreated = await prisma.documentTypes.create({
|
const documentTypeCreated = await prisma.documentTypes.create({
|
||||||
data: {
|
data: {
|
||||||
name: documentType.name,
|
name: documentType.name,
|
||||||
public_description: documentType.public_description,
|
public_description: documentType.public_description || "",
|
||||||
private_description: documentType.private_description,
|
private_description: documentType.private_description,
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
@ -1280,7 +1280,7 @@ export default async function main() {
|
|||||||
const createArgs: Prisma.DeedTypesCreateArgs = {
|
const createArgs: Prisma.DeedTypesCreateArgs = {
|
||||||
data: {
|
data: {
|
||||||
name: deedType.name,
|
name: deedType.name,
|
||||||
description: deedType.description,
|
description: deedType.description || "" ,
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
uid: deedType.office!.uid,
|
uid: deedType.office!.uid,
|
||||||
|
@ -788,6 +788,13 @@ export default async function main() {
|
|||||||
updated_at: new Date(),
|
updated_at: new Date(),
|
||||||
namespace: "super-admin",
|
namespace: "super-admin",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "PUT rib",
|
||||||
|
label: "Editer le RIB de l'office",
|
||||||
|
created_at: new Date(),
|
||||||
|
updated_at: new Date(),
|
||||||
|
namespace: "notary",
|
||||||
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
const collaboratorRules = rules.filter((rule) => rule.namespace === "collaborator");
|
const collaboratorRules = rules.filter((rule) => rule.namespace === "collaborator");
|
||||||
@ -1975,7 +1982,7 @@ export default async function main() {
|
|||||||
const documentTypeCreated = await prisma.documentTypes.create({
|
const documentTypeCreated = await prisma.documentTypes.create({
|
||||||
data: {
|
data: {
|
||||||
name: documentType.name,
|
name: documentType.name,
|
||||||
public_description: documentType.public_description,
|
public_description: documentType.public_description || "",
|
||||||
private_description: documentType.private_description,
|
private_description: documentType.private_description,
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
@ -1991,7 +1998,7 @@ export default async function main() {
|
|||||||
const createArgs: Prisma.DeedTypesCreateArgs = {
|
const createArgs: Prisma.DeedTypesCreateArgs = {
|
||||||
data: {
|
data: {
|
||||||
name: deedType.name,
|
name: deedType.name,
|
||||||
description: deedType.description,
|
description: deedType.description || "",
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
uid: deedType.office!.uid,
|
uid: deedType.office!.uid,
|
||||||
|
@ -31,7 +31,7 @@ export default class DeedTypesRepository extends BaseRepository {
|
|||||||
const createArgs: Prisma.DeedTypesCreateArgs = {
|
const createArgs: Prisma.DeedTypesCreateArgs = {
|
||||||
data: {
|
data: {
|
||||||
name: deedType.name,
|
name: deedType.name,
|
||||||
description: deedType.description,
|
description: deedType.description || "",
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
uid: deedType.office!.uid,
|
uid: deedType.office!.uid,
|
||||||
@ -59,7 +59,7 @@ export default class DeedTypesRepository extends BaseRepository {
|
|||||||
},
|
},
|
||||||
data: {
|
data: {
|
||||||
name: deedType.name,
|
name: deedType.name,
|
||||||
description: deedType.description,
|
description: deedType.description || "",
|
||||||
archived_at: deedType.archived_at,
|
archived_at: deedType.archived_at,
|
||||||
document_types: {
|
document_types: {
|
||||||
set: deedType.document_types?.map((documentType) => ({
|
set: deedType.document_types?.map((documentType) => ({
|
||||||
|
@ -30,7 +30,7 @@ export default class DocumentTypesRepository extends BaseRepository {
|
|||||||
const createArgs: Prisma.DocumentTypesCreateArgs = {
|
const createArgs: Prisma.DocumentTypesCreateArgs = {
|
||||||
data: {
|
data: {
|
||||||
name: documentType.name,
|
name: documentType.name,
|
||||||
public_description: documentType.public_description,
|
public_description: documentType.public_description || "",
|
||||||
private_description: documentType.private_description,
|
private_description: documentType.private_description,
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
@ -52,7 +52,7 @@ export default class DocumentTypesRepository extends BaseRepository {
|
|||||||
},
|
},
|
||||||
data: {
|
data: {
|
||||||
name: documentType.name,
|
name: documentType.name,
|
||||||
public_description: documentType.public_description,
|
public_description: documentType.public_description || "",
|
||||||
private_description: documentType.private_description,
|
private_description: documentType.private_description,
|
||||||
archived_at: documentType.archived_at,
|
archived_at: documentType.archived_at,
|
||||||
},
|
},
|
||||||
|
@ -67,6 +67,8 @@ export default class OfficesRepository extends BaseRepository {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
office_status: EOfficeStatus[office.office_status as keyof typeof EOfficeStatus],
|
office_status: EOfficeStatus[office.office_status as keyof typeof EOfficeStatus],
|
||||||
|
rib_url: office.rib_url,
|
||||||
|
rib_name: office.rib_name,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
return this.model.update(updateArgs);
|
return this.model.update(updateArgs);
|
||||||
|
@ -121,7 +121,6 @@ export default class IdNotService extends BaseService {
|
|||||||
code: code,
|
code: code,
|
||||||
grant_type: "authorization_code",
|
grant_type: "authorization_code",
|
||||||
});
|
});
|
||||||
console.log(this.variables.IDNOT_BASE_URL + this.variables.IDNOT_CONNEXION_URL + "?" + query.toString());
|
|
||||||
|
|
||||||
const token = await fetch(this.variables.IDNOT_BASE_URL + this.variables.IDNOT_CONNEXION_URL + "?" + query, { method: "POST" });
|
const token = await fetch(this.variables.IDNOT_BASE_URL + this.variables.IDNOT_CONNEXION_URL + "?" + query, { method: "POST" });
|
||||||
if(token.status !== 200) console.error(await token.text());
|
if(token.status !== 200) console.error(await token.text());
|
||||||
|
74
src/services/common/OfficeRibService/OfficeRibService.ts
Normal file
74
src/services/common/OfficeRibService/OfficeRibService.ts
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
import BaseService from "@Services/BaseService";
|
||||||
|
import { Service } from "typedi";
|
||||||
|
import * as AWS from "aws-sdk";
|
||||||
|
import { BackendVariables } from "@Common/config/variables/Variables";
|
||||||
|
import path from "path";
|
||||||
|
|
||||||
|
@Service()
|
||||||
|
export default class OfficerRibService extends BaseService {
|
||||||
|
private readonly s3: AWS.S3;
|
||||||
|
constructor(private variables: BackendVariables) {
|
||||||
|
super();
|
||||||
|
|
||||||
|
// Configure the AWS SDK for Scaleway
|
||||||
|
this.s3 = new AWS.S3({
|
||||||
|
accessKeyId: this.variables.SCW_ACCESS_KEY_ID,
|
||||||
|
secretAccessKey: this.variables.SCW_ACCESS_KEY_SECRET,
|
||||||
|
endpoint: this.variables.SCW_BUCKET_ENDPOINT, // Use the appropriate Scaleway endpoint
|
||||||
|
s3ForcePathStyle: true, // Needed for Scaleway's S3-compatible API
|
||||||
|
signatureVersion: "v4",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public async getByUid(uid: string, fileName: string) {
|
||||||
|
const key = path.join(this.variables.ENV, uid, fileName);
|
||||||
|
|
||||||
|
return new Promise<AWS.S3.GetObjectOutput>(async (resolve, reject) => {
|
||||||
|
this.s3.getObject(
|
||||||
|
{
|
||||||
|
Bucket: this.variables.SCW_BUCKET_NAME,
|
||||||
|
Key: key,
|
||||||
|
},
|
||||||
|
function (err, data) {
|
||||||
|
if (err) return reject(err);
|
||||||
|
resolve(data);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public async createOrUpdate(officeId: string, file: Express.Multer.File) {
|
||||||
|
const key = path.join(this.variables.ENV, officeId, file.originalname);
|
||||||
|
|
||||||
|
const uploadParams = {
|
||||||
|
Bucket: this.variables.SCW_BUCKET_NAME,
|
||||||
|
Key: key, // Example: 'example.txt'
|
||||||
|
Body: file.buffer, // Example: fs.createReadStream('/path/to/file')
|
||||||
|
ACL: "public-read", // Optional: Set the ACL if needed
|
||||||
|
};
|
||||||
|
|
||||||
|
return new Promise<string>((resolve, reject) => {
|
||||||
|
this.s3.putObject(uploadParams, function (err, data) {
|
||||||
|
if (err) return reject(err);
|
||||||
|
resolve(`https://lecoffre-bucket.s3.fr-par.scw.cloud/lecoffre-bucket/${key}`);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public async delete(officeId: string, fileName: string) {
|
||||||
|
const key = path.join(this.variables.ENV, officeId, fileName);
|
||||||
|
|
||||||
|
return new Promise<AWS.S3.GetObjectOutput>(async (resolve, reject) => {
|
||||||
|
this.s3.getObject(
|
||||||
|
{
|
||||||
|
Bucket: this.variables.SCW_BUCKET_NAME,
|
||||||
|
Key: key,
|
||||||
|
},
|
||||||
|
function (err, data) {
|
||||||
|
if (err) return reject(err);
|
||||||
|
resolve(data);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
28
src/services/customer/OfficesService/OfficesService.ts
Normal file
28
src/services/customer/OfficesService/OfficesService.ts
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
import {Prisma } from "@prisma/client";
|
||||||
|
import OfficesRepository from "@Repositories/OfficesRepository";
|
||||||
|
import BaseService from "@Services/BaseService";
|
||||||
|
import { Service } from "typedi";
|
||||||
|
|
||||||
|
|
||||||
|
@Service()
|
||||||
|
export default class OfficesService extends BaseService {
|
||||||
|
constructor(private officeRepository: OfficesRepository) {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description : Get all offices
|
||||||
|
* @throws {Error} If offices cannot be get
|
||||||
|
*/
|
||||||
|
public async get(query: Prisma.OfficesFindManyArgs) {
|
||||||
|
return this.officeRepository.findMany(query);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description : Get a office by uid
|
||||||
|
* @throws {Error} If office cannot be get
|
||||||
|
*/
|
||||||
|
public async getByUid(uid: string, query?: Prisma.OfficesInclude) {
|
||||||
|
return this.officeRepository.findOneByUid(uid, query);
|
||||||
|
}
|
||||||
|
}
|
@ -1,7 +1,9 @@
|
|||||||
import { Prisma } from "@prisma/client";
|
import { Offices, Prisma } from "@prisma/client";
|
||||||
import OfficesRepository from "@Repositories/OfficesRepository";
|
import OfficesRepository from "@Repositories/OfficesRepository";
|
||||||
import BaseService from "@Services/BaseService";
|
import BaseService from "@Services/BaseService";
|
||||||
import { Service } from "typedi";
|
import { Service } from "typedi";
|
||||||
|
import { Office as OfficeRessource } from "le-coffre-resources/dist/Notary";
|
||||||
|
|
||||||
|
|
||||||
@Service()
|
@Service()
|
||||||
export default class OfficesService extends BaseService {
|
export default class OfficesService extends BaseService {
|
||||||
@ -24,4 +26,12 @@ export default class OfficesService extends BaseService {
|
|||||||
public async getByUid(uid: string, query?: Prisma.OfficesInclude) {
|
public async getByUid(uid: string, query?: Prisma.OfficesInclude) {
|
||||||
return this.officeRepository.findOneByUid(uid, query);
|
return this.officeRepository.findOneByUid(uid, query);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description : Modify an office
|
||||||
|
* @throws {Error} If office cannot be modified
|
||||||
|
*/
|
||||||
|
public async update(uid: string, officeEntity: OfficeRessource): Promise<Offices> {
|
||||||
|
return this.officeRepository.update(uid, officeEntity);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@ export const initDocumentType = (documentType: DocumentType, office: Office): Pr
|
|||||||
return prisma.documentTypes.create({
|
return prisma.documentTypes.create({
|
||||||
data: {
|
data: {
|
||||||
name: documentType.name,
|
name: documentType.name,
|
||||||
public_description: documentType.public_description,
|
public_description: documentType.public_description || "" ,
|
||||||
private_description: documentType.private_description,
|
private_description: documentType.private_description,
|
||||||
archived_at: null,
|
archived_at: null,
|
||||||
office_uid: office.uid!,
|
office_uid: office.uid!,
|
||||||
@ -48,7 +48,7 @@ export const initDeedType = (deedType: DeedType): Promise<DeedTypes> => {
|
|||||||
const createArgs: Prisma.DeedTypesCreateArgs = {
|
const createArgs: Prisma.DeedTypesCreateArgs = {
|
||||||
data: {
|
data: {
|
||||||
name: deedType.name,
|
name: deedType.name,
|
||||||
description: deedType.description,
|
description: deedType.description || "",
|
||||||
office: {
|
office: {
|
||||||
connect: {
|
connect: {
|
||||||
uid: deedType.office!.uid,
|
uid: deedType.office!.uid,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user