2024-03-20 19:32:04 +01:00
|
|
|
import { AssetEntity } from 'src/infra/entities/asset.entity';
|
|
|
|
import { UserEntity } from 'src/infra/entities/user.entity';
|
2023-09-20 13:16:33 +02:00
|
|
|
import {
|
|
|
|
Column,
|
|
|
|
CreateDateColumn,
|
|
|
|
DeleteDateColumn,
|
|
|
|
Entity,
|
|
|
|
JoinTable,
|
|
|
|
ManyToOne,
|
|
|
|
OneToMany,
|
|
|
|
PrimaryGeneratedColumn,
|
|
|
|
UpdateDateColumn,
|
|
|
|
} from 'typeorm';
|
|
|
|
|
|
|
|
@Entity('libraries')
|
|
|
|
export class LibraryEntity {
|
|
|
|
@PrimaryGeneratedColumn('uuid')
|
|
|
|
id!: string;
|
|
|
|
|
|
|
|
@Column()
|
|
|
|
name!: string;
|
|
|
|
|
|
|
|
@OneToMany(() => AssetEntity, (asset) => asset.library)
|
|
|
|
@JoinTable()
|
|
|
|
assets!: AssetEntity[];
|
|
|
|
|
|
|
|
@ManyToOne(() => UserEntity, { onDelete: 'CASCADE', onUpdate: 'CASCADE', nullable: false })
|
|
|
|
owner!: UserEntity;
|
|
|
|
|
|
|
|
@Column()
|
|
|
|
ownerId!: string;
|
|
|
|
|
|
|
|
@Column()
|
|
|
|
type!: LibraryType;
|
|
|
|
|
|
|
|
@Column('text', { array: true })
|
|
|
|
importPaths!: string[];
|
|
|
|
|
|
|
|
@Column('text', { array: true })
|
|
|
|
exclusionPatterns!: string[];
|
|
|
|
|
|
|
|
@CreateDateColumn({ type: 'timestamptz' })
|
|
|
|
createdAt!: Date;
|
|
|
|
|
|
|
|
@UpdateDateColumn({ type: 'timestamptz' })
|
|
|
|
updatedAt!: Date;
|
|
|
|
|
|
|
|
@DeleteDateColumn({ type: 'timestamptz' })
|
|
|
|
deletedAt?: Date;
|
|
|
|
|
|
|
|
@Column({ type: 'timestamptz', nullable: true })
|
|
|
|
refreshedAt!: Date | null;
|
|
|
|
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
|
|
isVisible!: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
export enum LibraryType {
|
|
|
|
UPLOAD = 'UPLOAD',
|
|
|
|
EXTERNAL = 'EXTERNAL',
|
|
|
|
}
|