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管理员",关联所有分配的权限。

创建用户"admin@a.com",绑定管理员角色。

租户A创建员工

租户管理员登录,创建新用户"user1@a.com"。

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

将"user1@a.com"绑定到"客服"角色,该用户仅拥有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中移除该模块关联的所有权限。

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

相关推荐
IT界的奇葩1 天前
OAuth2 单点登录流程图
java·流程图·oauth2·单点登录·sso
Jeking2171 天前
进阶流程图绘制工具 Unione Flow Editor-- 击破样式痛点:全维度自定义解决方案
前端·流程图·workflow·unione flow·flow editor·unione cloud
nell_lee2 天前
利用ai快速绘制流程图/流程图自动迁移/快速格式化流程图
流程图
Jeking2172 天前
进阶流程图绘制工具 Unione Flow Editor-- 直击行业痛点:高扩展性解决方案解析
vue·流程图·workflow·unione flow·flow editor·unione cloud
Jeking2172 天前
新一代 Workflow 编辑器Unione Flow Editor :OA 审批流程实现案例
流程图·workflow·oa·unione flow·flow editor·unione cloud
Jeking2172 天前
进阶流程图绘制工具 Unione Flow Editor-- 巧用Event事件机制,破解复杂业务交互难题
流程图·vue3·workflow·unione flow·flow editor·unione cloud
Jeking2172 天前
初探新一代workflow编辑器unione flow editor:企业级流程设计的高效解决方案
编辑器·流程图·workflow·工作流·flow editor·unione cloud
源码技术栈3 天前
智慧工地微服务架构+Java+Spring Cloud +Uni-App +MySql开发,在微信公众号、小程序、H5、移动端
java·ai·saas·智慧工地·智慧工地项目·可视化大屏·智慧工地系统
程途拾光1583 天前
企业组织架构图导出Word 在线编辑免费工具
大数据·论文阅读·人工智能·信息可视化·架构·word·流程图
it_czz3 天前
ChatNode调用流程图
流程图