2025-04-07 15:12:12 -04:00
|
|
|
import { UpdatedAtTrigger, UpdateIdColumn } from 'src/decorators';
|
|
|
|
|
import { partners_delete_audit } from 'src/schema/functions';
|
2025-03-29 09:26:24 -04:00
|
|
|
import { UserTable } from 'src/schema/tables/user.table';
|
2025-03-28 10:40:09 -04:00
|
|
|
import {
|
2025-04-07 15:12:12 -04:00
|
|
|
AfterDeleteTrigger,
|
2025-03-28 10:40:09 -04:00
|
|
|
Column,
|
|
|
|
|
ColumnIndex,
|
|
|
|
|
CreateDateColumn,
|
|
|
|
|
ForeignKeyColumn,
|
|
|
|
|
Table,
|
|
|
|
|
UpdateDateColumn,
|
|
|
|
|
} from 'src/sql-tools';
|
|
|
|
|
|
|
|
|
|
@Table('partners')
|
2025-04-07 15:12:12 -04:00
|
|
|
@UpdatedAtTrigger('partners_updated_at')
|
|
|
|
|
@AfterDeleteTrigger({
|
|
|
|
|
name: 'partners_delete_audit',
|
|
|
|
|
scope: 'statement',
|
|
|
|
|
function: partners_delete_audit,
|
|
|
|
|
referencingOldTableAs: 'old',
|
|
|
|
|
when: 'pg_trigger_depth() = 0',
|
|
|
|
|
})
|
2025-03-28 10:40:09 -04:00
|
|
|
export class PartnerTable {
|
|
|
|
|
@ForeignKeyColumn(() => UserTable, { onDelete: 'CASCADE', primary: true })
|
|
|
|
|
sharedById!: string;
|
|
|
|
|
|
|
|
|
|
@ForeignKeyColumn(() => UserTable, { onDelete: 'CASCADE', primary: true })
|
|
|
|
|
sharedWithId!: string;
|
|
|
|
|
|
|
|
|
|
@CreateDateColumn()
|
|
|
|
|
createdAt!: Date;
|
|
|
|
|
|
|
|
|
|
@UpdateDateColumn()
|
|
|
|
|
updatedAt!: Date;
|
|
|
|
|
|
2025-04-07 15:12:12 -04:00
|
|
|
@Column({ type: 'boolean', default: false })
|
|
|
|
|
inTimeline!: boolean;
|
|
|
|
|
|
2025-03-28 10:40:09 -04:00
|
|
|
@ColumnIndex('IDX_partners_update_id')
|
|
|
|
|
@UpdateIdColumn()
|
|
|
|
|
updateId!: string;
|
|
|
|
|
}
|