All checks were successful
Test Asgard Runner / test (push) Successful in 3s
Root cause of all remaining 500s: TypeORM entities were scaffolded with "ideal" column names that don't match the Postgres columns created by the Rust migrations. Every query generated SQL referencing non-existent columns. Entity fixes: - notifications_config: email_enabled→email_alerts_enabled, removed 6 phantom columns (email_address, notify_on_start, notify_on_stop, notify_on_player_threshold, player_threshold), renamed 4 notify columns to match DB (notify_server_crash, notify_wipe_start, etc), added 3 missing columns (notify_server_offline, notify_store_purchase, notify_player_report) - team_members: joined_at→accepted_at (nullable, matches DB) - roles: removed description column (doesn't exist in DB) - scheduled_tasks: is_enabled→is_active, removed phantom last_run - wipe_profiles: pre/post_wipe_config nullable→NOT NULL with default Service/DTO fixes: - Updated all property references across notifications, team, schedules services and DTOs to match corrected entity names - Added is_active to UpdateTaskDto (frontend sends it, was being rejected by forbidNonWhitelisted validation) - Removed description from CreateRoleDto Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
55 lines
1.4 KiB
TypeScript
55 lines
1.4 KiB
TypeScript
import { Entity, PrimaryGeneratedColumn, Column, ManyToOne, JoinColumn } from 'typeorm';
|
|
import { License } from './license.entity';
|
|
|
|
@Entity('notifications_config')
|
|
export class NotificationsConfig {
|
|
@PrimaryGeneratedColumn('uuid')
|
|
id: string;
|
|
|
|
@Column({ type: 'uuid', unique: true })
|
|
license_id: string;
|
|
|
|
@Column({ type: 'text', nullable: true })
|
|
discord_webhook_url: string | null;
|
|
|
|
@Column({ type: 'boolean', default: false })
|
|
discord_enabled: boolean;
|
|
|
|
@Column({ type: 'text', nullable: true })
|
|
pushbullet_api_key: string | null;
|
|
|
|
@Column({ type: 'boolean', default: false })
|
|
pushbullet_enabled: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
email_alerts_enabled: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
notify_wipe_start: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
notify_wipe_complete: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
notify_wipe_failed: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
notify_server_crash: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
notify_server_offline: boolean;
|
|
|
|
@Column({ type: 'boolean', default: true })
|
|
notify_store_purchase: boolean;
|
|
|
|
@Column({ type: 'boolean', default: false })
|
|
notify_player_report: boolean;
|
|
|
|
@Column({ type: 'timestamptz', default: () => 'NOW()' })
|
|
created_at: Date;
|
|
|
|
@ManyToOne(() => License, { onDelete: 'CASCADE' })
|
|
@JoinColumn({ name: 'license_id' })
|
|
license: License;
|
|
}
|