import {
  Column,
  CreateDateColumn,
  DeleteDateColumn,
  Entity,
  JoinColumn,
  ManyToOne,
  PrimaryGeneratedColumn,
  UpdateDateColumn,
} from "typeorm"
import { Customer } from "./customer.entity"

@Entity("customer_access_tokens")
export class CustomerLogin {
  @PrimaryGeneratedColumn()
  id: number

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

  @Column({ type: "varchar", nullable: true })
  device_id?: string

  @Column({ type: "varchar", nullable: true })
  device_token?: string

  @Column({ type: "varchar", nullable: true })
  device_type?: string

  @Column({ type: "varchar", nullable: true })
  os_version?: string

  @Column({ type: "varchar", nullable: false })
  access_token: string

  @Column({ type: "timestamp", nullable: false })
  access_token_expire_at: Date

  @Column({ type: "varchar", nullable: true })
  refresh_token: string

  @Column({ type: "timestamp", nullable: true })
  refresh_token_expire_at: Date

  @Column({ type: "varchar", nullable: true })
  fcm_token: string

  @DeleteDateColumn()
  deleted_at: Date

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

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

  @ManyToOne(() => Customer, (customer) => customer.customer_logins)
  @JoinColumn({ name: "customer_id" })
  customer: Customer
}
