import { Entity, PrimaryGeneratedColumn, Column, CreateDateColumn, OneToMany, } from 'typeorm'; import { ShadowRunResult } from './shadow-run-result.entity'; @Entity({ schema: 'shared', name: 'shadow_runs' }) export class ShadowRun { @PrimaryGeneratedColumn('uuid') id: string; @Column({ name: 'tenant_id', type: 'uuid' }) tenantId: string; @Column({ type: 'varchar', length: 30 }) feature: string; @Column({ type: 'varchar', length: 20, default: 'running' }) status: string; @Column({ name: 'triggered_by', type: 'uuid', nullable: true }) triggeredBy: string; @Column({ name: 'prompt_messages', type: 'jsonb' }) promptMessages: any; @Column({ name: 'started_at', type: 'timestamptz', default: () => 'NOW()' }) startedAt: Date; @Column({ name: 'completed_at', type: 'timestamptz', nullable: true }) completedAt: Date; @CreateDateColumn({ name: 'created_at', type: 'timestamptz' }) createdAt: Date; @OneToMany(() => ShadowRunResult, (result) => result.run, { eager: true }) results: ShadowRunResult[]; // Virtual field populated via JOIN tenantName?: string; }