import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  OneToMany,
  ManyToOne,
  JoinColumn,
} from "typeorm"
import { BaseEntity } from "../../common/entities/base.entity"
import { Auth } from "../../auth/entities/auth.entity"
import { RolePermission } from "../../role-permissions/entities/role-permission.entity"

@Entity("permissions")
export class Permission extends BaseEntity {
  @PrimaryGeneratedColumn()
  id: number

  @Column({ type: "varchar", length: 100, nullable: false })
  group_key: string

  @Column({ type: "varchar", length: 100, nullable: false })
  permission_key: string

  @Column({ type: "varchar", length: 255, nullable: false })
  label: string

  @Column({ type: "text", nullable: true })
  description: string

  @Column({ type: "varchar", length: 100, nullable: true })
  group_name: string

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

  @OneToMany(
    () => RolePermission,
    (rolePermission) => rolePermission.permission,
  )
  rolePermissions: RolePermission[]

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

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

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