import Database from "@Common/databases/database"; import BaseRepository from "@Repositories/BaseRepository"; import { Service } from "typedi"; import { OfficeRoles, Prisma } 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 { 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 { 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 : Find one officeRole with office */ public async findOneByUidWithOffice(uid: string) { return this.model.findUnique({ where: { uid: uid, }, include: { office: true }, }); } /** * @description : Delete a officeRole */ public async delete(uid: string): Promise { return this.model.delete({ where: { uid: uid, }, }); } }