SAAS架构设计2-流程图-注册流程图

用户和租户的关系(多对多)注册流程说明

注册流程

个人账号注册(全局身份)

用户首先注册个人全局账号,填写基础信息(如邮箱、手机号、密码等)。

系统要求邮箱或手机号全局唯一,作为用户唯一标识。

注册完成后,用户拥有独立账号,但此时未关联任何租户。

加入或创建租户(租户关联)

加入现有租户:

用户通过租户邀请链接、租户ID或管理员审核的方式加入租户。

例如:酒店管理员发送邀请链接给员工,员工登录后确认加入。

创建新租户:

  1. 若用户是租户管理员(如新酒店或经销商),需在注册后补充租户信息(如酒店名称、营业执照等),系统自动创建租户(tenant),并绑定该用户为管理员设置字段(init_admin_id)。
  2. 创建租户与用户关系插入记录(tenant_user)

登录流程

  1. 登录平台账号
  2. 获得平台账号下面的租户信息(tenant),
  3. 点击进入平台管理中心。
  4. 判断当前账号是否为租户的默认管理员
是管理员:

根据租户ID,直接获得租户菜单权限,执行流程:tenant->tenant_type->module->menu

不是管理员:

根据租户的角色获得权限:user_role->role->menu

示例场景

租户A注册流程

租户A提交注册信息(名称、管理员账号)。

系统创建租户A记录,分配预设权限(如user:read, order:create)到tenant_permission。

自动创建角色"租户A管理员",关联所有分配的权限。

创建用户"[email protected]",绑定管理员角色。

租户A创建员工

租户管理员登录,创建新用户"[email protected]"。

创建新角色"客服",从tenant_permission中选择权限(如order:read)。

将"[email protected]"绑定到"客服"角色,该用户仅拥有order:read权限。

安全与约束

权限隔离:通过tenant_id确保租户数据完全隔离。

权限校验:

创建角色时,仅允许选择tenant_permission中的权限。

修改角色权限时,需校验权限是否属于租户。

唯一性约束:

租户名称全局唯一。

用户名在租户内唯一。

角色名称在租户内唯一。

优化建议

缓存机制:缓存租户的可用权限和角色权限,减少数据库查询。

审计日志:记录权限分配和角色变更操作,便于追溯。

批量操作:支持批量分配权限给角色,提升管理效率

'

用户和租户的关系(一对一)注册流程说明

租户注册流程:

  1. 租户填写注册信息(如租户名称、管理员用户信息)。

  2. 系统创建租户记录(tenant)。

  3. 系统为租户分配预设权限(插入到tenant_permission)(如分配基础权限包tenant_type_permission)。

  4. 系统为租户创建默认角色添加记录(role):

  • 管理员角色:拥有所有分配给该租户的权限(role_permission)。

  • 普通用户角色:可能有一些基本权限,由平台预设。

  1. 创建初始管理员用户(user),关联到租户,并分配管理员角色。

  2. 管理员用户可以登录,创建员工账号和角色,分配权限(仅限于tenant_permission中的权限)。

员工注册流程(由租户管理员操作):

  1. 租户管理员创建新用户(员工),指定用户名、密码等信息。

  2. 选择该用户要分配的角色(必须是该租户已有的角色,或者新建角色)。

  3. 新建角色时,租户管理员从该租户的可用权限(tenant_permission)中选择权限。

  4. 用户创建后,自动关联到所选角色,获得相应权限。

租户开通模块流程关键流程说明

****选择模块:****租户管理员在平台提供的模块列表中选择需要开通的模块(如订单管理)。

****权限同步:****插入tenant_module记录。根据module_permission表,将模块下所有权限插入tenant_permission。

****权限生效:****租户管理员可为角色分配新开通模块的权限。

关闭模块流程

移除模块:删除tenant_module中对应记录。

清理权限:从tenant_permission中移除该模块关联的所有权限。

角色更新:自动移除角色中已失效的权限(需触发校验)。

相关推荐
シ風箏3 天前
Django【应用 02】第一个Django应用开发流程图
python·django·流程图
零起飞3 天前
SAAS架构设计2-流程图-用户与租户之间对应关系图
流程图·saas·erp
MyikJ3 天前
互联网大厂Java面试:从Spring到微服务的挑战
数据库·spring boot·微服务·saas·java面试·缓存技术
IT技术猿猴6 天前
一键生成专业流程图:Draw.io与AI结合的高效绘图指南
人工智能·流程图·draw.io
黄交大彭于晏6 天前
论文流程图mermaid解决方案
流程图
diygwcom6 天前
推荐一款滴滴团队开源流程图编辑框架logic-flow
开源·流程图
霖008 天前
FPGA开发全流程
网络·经验分享·嵌入式硬件·fpga开发·流程图·fpga
AMT管理咨询13 天前
经典案例 | 筑基与跃升:解码制造企业产供销协同难题
流程图·制造·流程管理
RebekahHQ16 天前
Deepseek+Xmind:秒速生成思维导图与流程图
流程图·xmind·思维导图·deepseek