mirror of
https://github.com/immich-app/immich.git
synced 2025-12-02 11:15:30 -05:00
44 lines
1.1 KiB
TypeScript
44 lines
1.1 KiB
TypeScript
import { UpdatedAtTrigger, UpdateIdColumn } from 'src/decorators';
|
|
import { stack_delete_audit } from 'src/schema/functions';
|
|
import { AssetTable } from 'src/schema/tables/asset.table';
|
|
import { UserTable } from 'src/schema/tables/user.table';
|
|
import {
|
|
AfterDeleteTrigger,
|
|
CreateDateColumn,
|
|
ForeignKeyColumn,
|
|
Generated,
|
|
PrimaryGeneratedColumn,
|
|
Table,
|
|
Timestamp,
|
|
UpdateDateColumn,
|
|
} from 'src/sql-tools';
|
|
|
|
@Table('stack')
|
|
@UpdatedAtTrigger('stack_updatedAt')
|
|
@AfterDeleteTrigger({
|
|
scope: 'statement',
|
|
function: stack_delete_audit,
|
|
referencingOldTableAs: 'old',
|
|
when: 'pg_trigger_depth() = 0',
|
|
})
|
|
export class StackTable {
|
|
@PrimaryGeneratedColumn()
|
|
id!: Generated<string>;
|
|
|
|
@CreateDateColumn()
|
|
createdAt!: Generated<Timestamp>;
|
|
|
|
@UpdateDateColumn()
|
|
updatedAt!: Generated<Timestamp>;
|
|
|
|
@UpdateIdColumn()
|
|
updateId!: Generated<string>;
|
|
|
|
//TODO: Add constraint to ensure primary asset exists in the assets array
|
|
@ForeignKeyColumn(() => AssetTable, { nullable: false, unique: true })
|
|
primaryAssetId!: string;
|
|
|
|
@ForeignKeyColumn(() => UserTable, { onDelete: 'CASCADE', onUpdate: 'CASCADE' })
|
|
ownerId!: string;
|
|
}
|