mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-12 23:35:50 +00:00
49 lines
1.3 KiB
TypeScript
49 lines
1.3 KiB
TypeScript
import { BaseEntity, Entity, PrimaryGeneratedColumn, Column, OneToMany } from 'typeorm'
|
|
import { UserSetting } from './UserSetting'
|
|
|
|
// Moriz: I do not like the idea of having two user tables
|
|
@Entity('state_users', { engine: 'InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci' })
|
|
export class User extends BaseEntity {
|
|
@PrimaryGeneratedColumn('increment', { unsigned: true })
|
|
id: number
|
|
|
|
@Column({ name: 'index_id', type: 'smallint', default: 0, nullable: false })
|
|
indexId: number
|
|
|
|
@Column({ name: 'group_id', default: 0, unsigned: true })
|
|
groupId: number
|
|
|
|
@Column({ name: 'public_key', type: 'binary', length: 32, default: null, nullable: true })
|
|
pubkey: Buffer
|
|
|
|
@Column({ length: 255, nullable: true, default: null, collation: 'utf8mb4_unicode_ci' })
|
|
email: string
|
|
|
|
@Column({
|
|
name: 'first_name',
|
|
length: 255,
|
|
nullable: true,
|
|
default: null,
|
|
collation: 'utf8mb4_unicode_ci',
|
|
})
|
|
firstName: string
|
|
|
|
@Column({
|
|
name: 'last_name',
|
|
length: 255,
|
|
nullable: true,
|
|
default: null,
|
|
collation: 'utf8mb4_unicode_ci',
|
|
})
|
|
lastName: string
|
|
|
|
@Column({ length: 255, nullable: true, default: null, collation: 'utf8mb4_unicode_ci' })
|
|
username: string
|
|
|
|
@Column({ type: 'bool', default: false })
|
|
disabled: boolean
|
|
|
|
@OneToMany(() => UserSetting, (userSetting) => userSetting.user)
|
|
settings: UserSetting[]
|
|
}
|