import {
  Entity,
  PrimaryGeneratedColumn,
  CreateDateColumn,
  UpdateDateColumn,
  DeleteDateColumn,
  ManyToOne,
  JoinColumn,
  Column,
} from "typeorm"
import { Role } from "../../role/entities/role.entity"
import { Permission } from "../../permission/entities/permission.entity"
import { Modules } from "src/modules/module/entities/module.entity"

@Entity("role_permissions")
export class RolePermission {
  @PrimaryGeneratedColumn()
  id: number

  @Column({ type: "int", nullable: false })
  role_id: number

  @Column({ type: "int", nullable: true })
  module_id: number

  @Column({ type: "int", nullable: false })
  permission_id: number

  @CreateDateColumn({ type: "timestamp", default: () => "NOW()" })
  created_at: Date

  @UpdateDateColumn({ type: "timestamp", default: () => "NOW()" })
  updated_at: Date

  @DeleteDateColumn()
  deleted_at: Date

  @ManyToOne(() => Role, (role) => role.role_permissions, {
    onDelete: "CASCADE",
  })
  @JoinColumn({ name: "role_id" })
  role: Role

  @ManyToOne(() => Modules, (module) => module.role_permissions, {
    onDelete: "CASCADE",
  })
  @JoinColumn({ name: "module_id" })
  module: Modules

  @ManyToOne(() => Permission, (permission) => permission.role_permissions, {
    onDelete: "CASCADE",
  })
  @JoinColumn({ name: "permission_id" })
  permission: Permission
}
