import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  ManyToOne,
  JoinColumn,
} from "typeorm"
import { BaseEntity } from "../../common/entities/base.entity"
import { Role } from "../../role/entities/role.entity"
import { Permission } from "../../permissions/entities/permission.entity"
import { Company } from "../../company/entities/company.entity"
import { Auth } from "../../auth/entities/auth.entity"

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

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

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

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

  @Column({
    type: "smallint",
    default: 1,
  })
  status: number

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

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

  @ManyToOne(() => Company)
  @JoinColumn({ name: "company_id" })
  company: Company

  @ManyToOne(() => Auth)
  @JoinColumn({ name: "created_by" })
  createdByUser: Auth

  @ManyToOne(() => Auth)
  @JoinColumn({ name: "updated_by" })
  updatedByUser: Auth

  @ManyToOne(() => Auth)
  @JoinColumn({ name: "deleted_by" })
  deletedByUser: Auth
}
