forked from Cutlery/immich
* Refactor docker-compose to its own folder * Added FastAPI development environment * Added support for GPU in docker file * Added image classification * creating endpoint for smart Image info * added logo with white background on ios * Added endpoint and trigger for image tagging * Classify image and save into database * Update readme
57 lines
1.1 KiB
TypeScript
57 lines
1.1 KiB
TypeScript
import { Column, Entity, JoinColumn, OneToOne, PrimaryColumn, PrimaryGeneratedColumn, Unique } from 'typeorm';
|
|
import { ExifEntity } from './exif.entity';
|
|
import { SmartInfoEntity } from './smart-info.entity';
|
|
|
|
@Entity('assets')
|
|
@Unique(['deviceAssetId', 'userId', 'deviceId'])
|
|
export class AssetEntity {
|
|
@PrimaryGeneratedColumn('uuid')
|
|
id: string;
|
|
|
|
@Column()
|
|
deviceAssetId: string;
|
|
|
|
@Column()
|
|
userId: string;
|
|
|
|
@Column()
|
|
deviceId: string;
|
|
|
|
@Column()
|
|
type: AssetType;
|
|
|
|
@Column()
|
|
originalPath: string;
|
|
|
|
@Column({ nullable: true })
|
|
resizePath: string;
|
|
|
|
@Column()
|
|
createdAt: string;
|
|
|
|
@Column()
|
|
modifiedAt: string;
|
|
|
|
@Column({ type: 'boolean', default: false })
|
|
isFavorite: boolean;
|
|
|
|
@Column({ nullable: true })
|
|
mimeType: string;
|
|
|
|
@Column({ nullable: true })
|
|
duration: string;
|
|
|
|
@OneToOne(() => ExifEntity, (exifEntity) => exifEntity.asset)
|
|
exifInfo: ExifEntity;
|
|
|
|
@OneToOne(() => SmartInfoEntity, (smartInfoEntity) => smartInfoEntity.asset)
|
|
smartInfo: SmartInfoEntity;
|
|
}
|
|
|
|
export enum AssetType {
|
|
IMAGE = 'IMAGE',
|
|
VIDEO = 'VIDEO',
|
|
AUDIO = 'AUDIO',
|
|
OTHER = 'OTHER',
|
|
}
|