Files
SerpentRace/SerpentRace_Backend/src/Domain/Organization/OrganizationAggregate.ts
T
2025-10-27 20:22:39 +01:00

52 lines
1.4 KiB
TypeScript

import { Entity, PrimaryGeneratedColumn, Column, CreateDateColumn, UpdateDateColumn, OneToMany } from 'typeorm';
import { UserAggregate } from '../User/UserAggregate';
export const OrganizationState = {
REGISTERED: 0,
ACTIVE: 1,
SOFT_DELETE: 2
} as const;
export type OrganizationStateType = typeof OrganizationState[keyof typeof OrganizationState];
@Entity('Organizations')
export class OrganizationAggregate {
@PrimaryGeneratedColumn('uuid')
id!: string;
@Column({ type: 'varchar', length: 255 })
name!: string;
@Column({ type: 'varchar', length: 100 })
contactfname!: string;
@Column({ type: 'varchar', length: 100 })
contactlname!: string;
@Column({ type: 'varchar', length: 20 })
contactphone!: string;
@Column({ type: 'varchar', length: 255 })
contactemail!: string;
@Column({ type: 'int', default: OrganizationState.REGISTERED })
state!: OrganizationStateType;
@CreateDateColumn()
regdate!: Date;
@UpdateDateColumn({ name: 'updateDate' })
updateDate!: Date;
@Column({ type: 'varchar', length: 500, nullable: true })
url!: string | null;
@Column({ type: 'int', default: 0 })
userinorg!: number;
@Column({ type: 'int', nullable: true })
maxOrganizationalDecks!: number | null;
@OneToMany(() => UserAggregate, user => user.orgid)
users!: UserAggregate[];
}