import { Column, Entity, JoinTable, ManyToMany, PrimaryGeneratedColumn, } from "typeorm"; import { Master } from "./Master"; import { MasterPermission } from "./MasterPermission"; @Entity("master_role", { comment: "Roles que se le pueden agregar a un usuario (master) en la plataforma.", }) export class MasterRole { @PrimaryGeneratedColumn({ type: "int", comment: "Número de identificación (ID) único de cada registro.", }) id: number; @Column({ length: 10, type: "varchar", unique: true, comment: "Código único del rol.", }) code: string; @Column({ length: 40, type: "varchar", comment: 'Id de la variable que se encuentra en los archivos "locale" para el multilenguaje.\r\n\r\nCabe recordar qué los usuarios (master) también pueden crear roles, estos deben ir normal, sin id para el lenguaje.', }) name: string; @Column({ length: 40, nullable: true, type: "varchar", default: null, comment: 'Id de la variable que se encuentra en los archivos "locale" para el multilenguaje.\r\n\r\nCabe recordar qué los usuarios (master) también pueden crear roles, estos deben ir normal, sin id para el lenguaje.', }) description: string | null; @Column({ default: 1, type: "int", width: 1, comment: "Estado del registro, es decir:\r\n1. Activo: Es visible en la plataforma.\r\n0. Inactivo: No será visible en la plataforma.", }) status: number; @ManyToMany( () => MasterPermission, (masterPermission) => masterPermission.roles ) @JoinTable({ name: "master_role_permission", joinColumn: { name: "role", referencedColumnName: "id", }, inverseJoinColumn: { name: "permission", referencedColumnName: "id", }, }) roles_permissions: MasterPermission[]; @ManyToMany(() => Master, (master) => master.masters_roles) @JoinTable({ name: "master_assigned_role", joinColumn: { name: "role", referencedColumnName: "id", }, inverseJoinColumn: { name: "master", referencedColumnName: "id", }, }) masters_roles: Master[]; }