add roles and rules repositories
This commit is contained in:
parent
831733d090
commit
aa30e8badd
@ -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
|
||||||
|
42
src/common/repositories/OfficeRoleHasRulesRepository.ts
Normal file
42
src/common/repositories/OfficeRoleHasRulesRepository.ts
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
42
src/common/repositories/RolesHasRulesRepository.ts
Normal file
42
src/common/repositories/RolesHasRulesRepository.ts
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
111
src/common/repositories/RolesRepository.ts
Normal file
111
src/common/repositories/RolesRepository.ts
Normal 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,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
83
src/common/repositories/RulesRepository.ts
Normal file
83
src/common/repositories/RulesRepository.ts
Normal 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,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -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) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user