user.entity.ts 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import { Entity, PrimaryGeneratedColumn, Column, ManyToMany, JoinTable, CreateDateColumn, UpdateDateColumn, OneToMany, ManyToOne, JoinColumn } from 'typeorm';
  2. import { Role } from './role.entity';
  3. import { DeleteStatus, DisabledStatus } from '@/share/types';
  4. import { File } from '@/server/modules/files/file.entity';
  5. import { DataScopeType } from '@/server/modules/departments/department.entity';
  6. @Entity({ name: 'users' })
  7. export class UserEntity {
  8. @PrimaryGeneratedColumn({ unsigned: true, comment: '用户ID' })
  9. id!: number;
  10. @Column({ name: 'username', type: 'varchar', length: 255, unique: true, comment: '用户名' })
  11. username!: string;
  12. @Column({ name: 'password', type: 'varchar', length: 255, comment: '密码' })
  13. password!: string;
  14. @Column({ name: 'phone', type: 'varchar', length: 255, nullable: true, comment: '手机号' })
  15. phone!: string | null;
  16. @Column({ name: 'email', type: 'varchar', length: 255, nullable: true, comment: '邮箱' })
  17. email!: string | null;
  18. @Column({ name: 'nickname', type: 'varchar', length: 255, nullable: true, comment: '昵称' })
  19. nickname!: string | null;
  20. @Column({ name: 'name', type: 'varchar', length: 255, nullable: true, comment: '真实姓名' })
  21. name!: string | null;
  22. @Column({ name: 'avatar', type: 'varchar', length: 255, nullable: true, comment: '头像' })
  23. avatar!: string | null;
  24. @Column({ name: 'is_disabled', type: 'int', default: DisabledStatus.ENABLED, comment: '是否禁用(0:启用,1:禁用)' })
  25. isDisabled!: DisabledStatus;
  26. @Column({ name: 'is_deleted', type: 'int', default: DeleteStatus.NOT_DELETED, comment: '是否删除(0:未删除,1:已删除)' })
  27. isDeleted!: DeleteStatus;
  28. @ManyToMany(() => Role)
  29. @JoinTable()
  30. roles!: Role[];
  31. @OneToMany(() => File, file => file.uploadUser)
  32. uploadFiles!: File[];
  33. @Column({ name: 'default_department_id', type: 'int', unsigned: true, nullable: true, comment: '默认部门ID' })
  34. defaultDepartmentId?: number;
  35. @Column({ name: 'data_scope_type', type: 'enum', enum: DataScopeType, default: DataScopeType.PERSONAL, comment: '数据范围类型' })
  36. dataScopeType!: DataScopeType;
  37. @CreateDateColumn({ name: 'created_at', type: 'timestamp' })
  38. createdAt!: Date;
  39. @UpdateDateColumn({ name: 'updated_at', type: 'timestamp' })
  40. updatedAt!: Date;
  41. @Column({ name: 'created_by', type: 'int', nullable: true, comment: '创建用户ID' })
  42. createdBy?: number;
  43. @Column({ name: 'updated_by', type: 'int', nullable: true, comment: '更新用户ID' })
  44. updatedBy?: number;
  45. constructor(partial?: Partial<UserEntity>) {
  46. Object.assign(this, partial);
  47. }
  48. }