import { PrimaryColumn, Entity, Index, Column } from "typeorm"; import { id } from "../id.js"; @Entity() @Index(["name", "host"], { unique: true }) export class Emoji { @PrimaryColumn(id()) public id: string; @Column("timestamp with time zone", { nullable: true, }) public updatedAt: Date | null; @Index() @Column("varchar", { length: 128, }) public name: string; @Index() @Column("varchar", { length: 128, nullable: true, }) public host: string | null; @Column("varchar", { length: 128, nullable: true, }) public category: string | null; @Column("varchar", { length: 512, }) public originalUrl: string; @Column("varchar", { length: 512, default: "", }) public publicUrl: string; @Column("varchar", { length: 512, nullable: true, }) public uri: string | null; // publicUrlの方のtypeが入る // (mime) @Column("varchar", { length: 64, nullable: true, }) public type: string | null; @Column("varchar", { array: true, length: 128, default: "{}", }) public aliases: string[]; @Column("varchar", { length: 1024, nullable: true, }) public license: string | null; @Column("integer", { nullable: true, comment: "Image width", }) public width: number | null; @Column("integer", { nullable: true, comment: "Image height", }) public height: number | null; }