lecoffre-back/src/common/repositories/OfficeRolesRepository.ts
2023-06-29 15:23:50 +02:00

94 lines
2.1 KiB
TypeScript

import Database from "@Common/databases/database";
import BaseRepository from "@Repositories/BaseRepository";
import { Service } from "typedi";
import { OfficeRoles, Prisma, Rules } from "@prisma/client";
import { OfficeRole } from "le-coffre-resources/dist/SuperAdmin";
@Service()
export default class OfficeRolesRepository extends BaseRepository {
constructor(private database: Database) {
super();
}
protected get model() {
return this.database.getClient().officeRoles;
}
protected get instanceDb() {
return this.database.getClient();
}
/**
* @description : Find many officeRoles
*/
public async findMany(query: Prisma.OfficeRolesFindManyArgs) {
query.take = Math.min(query.take || this.defaultFetchRows, this.maxFetchRows);
return this.model.findMany(query);
}
/**
* @description : Create new officeRole with rules
*/
public async create(officeRole: OfficeRole): Promise<OfficeRoles & {rules: Rules[]}> {
const createArgs: Prisma.OfficeRolesCreateArgs = {
data: {
name: officeRole.name,
office: {
connect: {
uid: officeRole.office.uid,
},
},
rules: {
connect: officeRole.rules?.map((rule) => ({
uid: rule.uid!,
})),
},
},
};
return this.model.create({...createArgs, include: {rules: true}});
}
/**
* @description : Update data of a officeRole with rules
*/
public async update(officeRole: OfficeRole): Promise<OfficeRoles & {rules: Rules[]}> {
const updateArgs: Prisma.OfficeRolesUpdateArgs = {
where: {
uid: officeRole.uid,
},
data: {
name: officeRole.name,
rules: {
set: officeRole.rules?.map((rule) => ({
uid: rule.uid!,
})),
},
},
};
return this.model.update({...updateArgs, include: {rules: true}});
}
/**
* @description : Find one officeRole
*/
public async findOneByUid(uid: string, query?: Prisma.OfficeRolesInclude) {
return this.model.findUnique({
where: {
uid: uid,
},
include: query,
});
}
/**
* @description : Delete a officeRole
*/
public async delete(uid: string): Promise<OfficeRoles> {
return this.model.delete({
where: {
uid: uid,
},
});
}
}