add roles and rules repositories

This commit is contained in:
OxSaitama 2023-06-19 17:58:12 +02:00
parent 831733d090
commit aa30e8badd
6 changed files with 335 additions and 1 deletions

View File

@ -54,6 +54,8 @@ model Users {
idNot String @unique @db.VarChar(255) idNot String @unique @db.VarChar(255)
contact Contacts @relation(fields: [contact_uid], references: [uid], onDelete: Cascade) contact Contacts @relation(fields: [contact_uid], references: [uid], onDelete: Cascade)
contact_uid String @unique @db.VarChar(255) contact_uid String @unique @db.VarChar(255)
role Roles @relation(fields: [roles_uid], references: [uid])
roles_uid String
created_at DateTime? @default(now()) created_at DateTime? @default(now())
updated_at DateTime? @updatedAt updated_at DateTime? @updatedAt
office_membership Offices @relation(fields: [office_uid], references: [uid], onDelete: Cascade) office_membership Offices @relation(fields: [office_uid], references: [uid], onDelete: Cascade)
@ -205,7 +207,7 @@ model Files {
file_path String @unique @db.VarChar(255) file_path String @unique @db.VarChar(255)
file_name String @db.VarChar(255) file_name String @db.VarChar(255)
mimetype String @db.VarChar(255) mimetype String @db.VarChar(255)
size Int size Int
archived_at DateTime? archived_at DateTime?
key String? @db.VarChar(255) key String? @db.VarChar(255)
created_at DateTime? @default(now()) created_at DateTime? @default(now())
@ -296,6 +298,55 @@ model DeedTypeHasDocumentTypes {
@@map("deed_type_has_document_types") @@map("deed_type_has_document_types")
} }
model Roles {
uid String @id @unique @default(uuid())
name String @db.VarChar(255)
created_at DateTime? @default(now())
updated_at DateTime? @updatedAt
role_has_rules RolesHasRules[]
office_role_has_rules OfficesRolesHasRules[]
users Users[]
@@map("roles")
}
model Rules {
uid String @id @unique @default(uuid())
name String @db.VarChar(255)
created_at DateTime? @default(now())
updated_at DateTime? @updatedAt
role_has_rules RolesHasRules? @relation(fields: [role_has_rules_uid], references: [uid])
role_has_rules_uid String?
office_role_has_rules OfficesRolesHasRules? @relation(fields: [office_role_has_rules_uid], references: [uid])
office_role_has_rules_uid String?
@@map("rules")
}
model RolesHasRules {
uid String @id @unique @default(uuid())
role Roles @relation(fields: [role_uid], references: [uid], onDelete: Cascade)
role_uid String @db.VarChar(255)
rule_uid String @db.VarChar(255)
created_at DateTime? @default(now())
updated_at DateTime? @updatedAt
rules Rules[]
@@map("role_has_rules")
}
model OfficesRolesHasRules {
uid String @id @unique @default(uuid())
role Roles @relation(fields: [role_uid], references: [uid], onDelete: Cascade)
role_uid String @db.VarChar(255)
rule_uid String @db.VarChar(255)
created_at DateTime? @default(now())
updated_at DateTime? @updatedAt
rules Rules[]
@@map("office_role_has_rules")
}
enum ECivility { enum ECivility {
MALE MALE
FEMALE FEMALE

View File

@ -0,0 +1,42 @@
import Database from "@Common/databases/database";
import BaseRepository from "@Repositories/BaseRepository";
import { Service } from "typedi";
import { OfficesRolesHasRules, Prisma } from "@prisma/client";
@Service()
export default class OfficeRoleHasRulesRepository extends BaseRepository {
constructor(private database: Database) {
super();
}
protected get model() {
return this.database.getClient().officesRolesHasRules;
}
protected get instanceDb() {
return this.database.getClient();
}
/**
* @description : Find many relations between office roles and rules
*/
public async findMany(query: any): Promise<OfficesRolesHasRules[]> {
query.take = Math.min(query.take || this.defaultFetchRows, this.maxFetchRows);
return this.model.findMany(query);
}
/**
* @description : Find one relation between an office role and rules
*/
public async findOneByUid(uid: string, query?: any): Promise<OfficesRolesHasRules | null> {
const findOneArgs: Prisma.OfficesRolesHasRulesFindUniqueArgs = {
where: {
uid: uid,
},
};
if (query) {
findOneArgs.include = query;
}
const roleEntity = await this.model.findUnique(findOneArgs);
return roleEntity;
}
}

View File

@ -0,0 +1,42 @@
import Database from "@Common/databases/database";
import BaseRepository from "@Repositories/BaseRepository";
import { Service } from "typedi";
import { RolesHasRules, Prisma } from "@prisma/client";
@Service()
export default class RolesHasRulesRepository extends BaseRepository {
constructor(private database: Database) {
super();
}
protected get model() {
return this.database.getClient().rolesHasRules;
}
protected get instanceDb() {
return this.database.getClient();
}
/**
* @description : Find many relations between basic roles and rules
*/
public async findMany(query: any): Promise<RolesHasRules[]> {
query.take = Math.min(query.take || this.defaultFetchRows, this.maxFetchRows);
return this.model.findMany(query);
}
/**
* @description : Find one relation between an basic role and rules
*/
public async findOneByUid(uid: string, query?: any): Promise<RolesHasRules | null> {
const findOneArgs: Prisma.RolesHasRulesFindUniqueArgs = {
where: {
uid: uid,
},
};
if (query) {
findOneArgs.include = query;
}
const roleEntity = await this.model.findUnique(findOneArgs);
return roleEntity;
}
}

View File

@ -0,0 +1,111 @@
import Database from "@Common/databases/database";
import BaseRepository from "@Repositories/BaseRepository";
import { Service } from "typedi";
import { Roles, Prisma } from "@prisma/client";
import { Role } from "le-coffre-resources/dist/SuperAdmin";
@Service()
export default class RolesRepository extends BaseRepository {
constructor(private database: Database) {
super();
}
protected get model() {
return this.database.getClient().roles;
}
protected get instanceDb() {
return this.database.getClient();
}
/**
* @description : Find many roles
*/
public async findMany(query: any): Promise<Roles[]> {
query.take = Math.min(query.take || this.defaultFetchRows, this.maxFetchRows);
return this.model.findMany(query);
}
/**
* @description : Create new role with rules
*/
public async create(role: Role): Promise<Roles> {
const createArgs: Prisma.RolesCreateArgs = {
data: {
name: role.name,
role_has_rules: {
createMany: {
data: role.role_has_rules!.rules.map((relation) => ({
rule_uid: relation.uid!,
})),
skipDuplicates: true,
},
},
},
};
return this.model.create(createArgs);
}
/**
* @description : Update data of a role with rules
*/
public async update(role: Role): Promise<Roles> {
const updateArgs: Prisma.RolesUpdateArgs = {
where: {
uid: role.uid,
},
data: {
name: role.name,
role_has_rules: {
deleteMany: { role_uid: role.uid },
createMany: {
data: role.role_has_rules!.rules.map((relation) => ({
rule_uid: relation.uid!,
})),
skipDuplicates: true,
},
},
},
};
if(role.office_role_has_rules) {
updateArgs.data.office_role_has_rules = {
deleteMany: { role_uid: role.uid },
createMany: {
data: role.office_role_has_rules.rules.map((relation) => ({
rule_uid: relation.uid!,
})),
skipDuplicates: true,
},
};
}
return this.model.update(updateArgs);
}
/**
* @description : Find one role
*/
public async findOneByUid(uid: string, query?: any): Promise<Roles | null> {
const findOneArgs: Prisma.RolesFindUniqueArgs = {
where: {
uid: uid,
},
};
if (query) {
findOneArgs.include = query;
}
const roleEntity = await this.model.findUnique(findOneArgs);
return roleEntity;
}
/**
* @description : Delete a role
*/
public async delete(uid: string): Promise<Roles> {
return this.model.delete({
where: {
uid: uid,
},
});
}
}

View File

@ -0,0 +1,83 @@
import Database from "@Common/databases/database";
import BaseRepository from "@Repositories/BaseRepository";
import { Service } from "typedi";
import { Rules, Prisma } from "@prisma/client";
import { Rule } from "le-coffre-resources/dist/SuperAdmin";
@Service()
export default class RulesRepository extends BaseRepository {
constructor(private database: Database) {
super();
}
protected get model() {
return this.database.getClient().rules;
}
protected get instanceDb() {
return this.database.getClient();
}
/**
* @description : Find many rules
*/
public async findMany(query: any): Promise<Rules[]> {
query.take = Math.min(query.take || this.defaultFetchRows, this.maxFetchRows);
return this.model.findMany(query);
}
/**
* @description : Create new rule
*/
public async create(rule: Rule): Promise<Rules> {
const createArgs: Prisma.RulesCreateArgs = {
data: {
name: rule.name
},
};
return this.model.create(createArgs);
}
/**
* @description : Update data of a rule
*/
public async update(rule: Rule): Promise<Rules> {
const updateArgs: Prisma.RulesUpdateArgs = {
where: {
uid: rule.uid,
},
data: {
name: rule.name
},
};
return this.model.update(updateArgs);
}
/**
* @description : Find one rule
*/
public async findOneByUid(uid: string, query?: any): Promise<Rules | null> {
const findOneArgs: Prisma.RulesFindUniqueArgs = {
where: {
uid: uid,
},
};
if (query) {
findOneArgs.include = query;
}
const ruleEntity = await this.model.findUnique(findOneArgs);
return ruleEntity;
}
/**
* @description : Delete a rule
*/
public async delete(uid: string): Promise<Rules> {
return this.model.delete({
where: {
uid: uid,
},
});
}
}

View File

@ -61,6 +61,11 @@ export default class UsersRepository extends BaseRepository {
address: {}, address: {},
}, },
}, },
role: {
connect: {
uid: user.role!.uid,
},
}
}, },
}; };
if (user.contact!.address) { if (user.contact!.address) {