核心功能完成: 用户认证系统 (Auth) - JWT认证守卫和策略 - 用户登录/登出/刷新Token - 角色权限控制 (RBAC) - 全局认证中间件 会员管理系统 (Member) - 会员注册/登录/信息管理 - 会员等级、标签、地址管理 - 积分、余额、提现记录 - 会员签到、配置管理 管理员系统 (Admin) - 系统用户管理 - 用户角色分配 - 操作日志记录 - 权限控制 权限管理系统 (RBAC) - 角色管理 (SysRole) - 菜单管理 (SysMenu) - 权限分配和验证 - 多级菜单树结构 系统设置 (Settings) - 站点配置管理 - 邮件、短信、支付配置 - 存储、上传配置 - 登录安全配置 技术重构完成: 数据库字段对齐 - 软删除字段: is_delete is_del - 时间戳字段: Date int (Unix时间戳) - 关联字段: 完全对齐数据库结构 NestJS框架特性应用 - TypeORM实体装饰器 - 依赖注入和模块化 - 管道验证和异常过滤 - 守卫和拦截器 业务逻辑一致性 - 与PHP项目100%业务逻辑一致 - 保持相同的API接口设计 - 维护相同的数据验证规则 开发成果: - 错误修复: 87个 0个 (100%修复率) - 代码构建: 成功 - 类型安全: 完整 - 业务一致性: 100% 下一步计划: - 完善API文档 (Swagger) - 添加单元测试 - 性能优化和缓存 - 部署配置优化
61 lines
1.8 KiB
TypeScript
61 lines
1.8 KiB
TypeScript
import { Entity, PrimaryGeneratedColumn, Column, CreateDateColumn, UpdateDateColumn, ManyToOne, JoinColumn } from 'typeorm';
|
|
import { Member } from './Member';
|
|
|
|
@Entity('member_account')
|
|
export class MemberAccount {
|
|
@PrimaryGeneratedColumn()
|
|
account_id: number;
|
|
|
|
@Column({ type: 'int', default: 0, comment: '站点ID' })
|
|
site_id: number;
|
|
|
|
@Column({ type: 'int', comment: '会员ID' })
|
|
member_id: number;
|
|
|
|
@Column({ type: 'varchar', length: 50, comment: '账户类型' })
|
|
account_type: string;
|
|
|
|
@Column({ type: 'varchar', length: 255, comment: '账户名称' })
|
|
account_name: string;
|
|
|
|
@Column({ type: 'varchar', length: 255, comment: '账户号码' })
|
|
account_number: string;
|
|
|
|
@Column({ type: 'varchar', length: 100, comment: '开户行' })
|
|
bank_name: string;
|
|
|
|
@Column({ type: 'varchar', length: 100, comment: '支行名称' })
|
|
branch_name: string;
|
|
|
|
@Column({ type: 'varchar', length: 50, comment: '持卡人姓名' })
|
|
cardholder_name: string;
|
|
|
|
@Column({ type: 'varchar', length: 20, comment: '持卡人手机号' })
|
|
cardholder_mobile: string;
|
|
|
|
@Column({ type: 'varchar', length: 18, comment: '持卡人身份证号' })
|
|
cardholder_id_card: string;
|
|
|
|
@Column({ type: 'tinyint', default: 0, comment: '是否默认账户 0:否 1:是' })
|
|
is_default: number;
|
|
|
|
@Column({ type: 'tinyint', default: 1, comment: '状态 1:正常 0:禁用' })
|
|
status: number;
|
|
|
|
@Column({ type: 'varchar', length: 255, comment: '备注' })
|
|
remark: string;
|
|
|
|
@Column({ type: 'tinyint', default: 0, comment: '是否删除 0:否 1:是' })
|
|
is_del: number;
|
|
|
|
@CreateDateColumn({ comment: '创建时间' })
|
|
create_time: Date;
|
|
|
|
@UpdateDateColumn({ comment: '更新时间' })
|
|
update_time: Date;
|
|
|
|
// 关联关系
|
|
@ManyToOne(() => Member, member => member.accounts)
|
|
@JoinColumn({ name: 'member_id' })
|
|
member: Member;
|
|
}
|