【设计】多层级账户-下钻/回翻/切换角色

2023-10-11  本文已影响0人  小胖学编程

在账户体系设计中,账户关系可能存在多层级,例如:厂商(一汽大众)—> 经销商门店(北望路4S店)—> 员工账户(员工)。

背景

假设有一个【报表域】需要展示账户的经营概览信息。

厂商:看到的是所有经销商门店的汇总以及明细信息;
门店:看到的是所有员工账户的汇总以及明细信息;
员工:看到的是自己的汇总信息;

厂商(厂商Id)下可以拥有N个厂商管理员(userId)角色;
门店(门店Id)下可以拥有N个门店管理员(userId)角色;
员工子账户(员工userId)是最小的粒度;

员工的存在流动性,即一个员工在不同的时期可以在多个门店工作。
一个管理员既可以是厂商管理员,也可以是门店管理员,也可以是员工账户;

账户层级关系.png

诉求

厂商管理员可以下钻到别的门店账户中,查询具体门店账户的信息;
厂商管理员如果是门店管理员的话,那么他可以切换到自己的门店中;
如果是离职员工账户的话,那么前门店可以查询它离职前的数据,所在职的门店可以查询它入职后的数据;

解法

如何实现下钻功能

下钻功能类似于代登录,但是代登录的实现非常麻烦,会涉及到权限、安全等控制。那么我们如何实现下钻的功能呢?

(1)后端协议的制定

假设厂商管理员登录后,他想查询下钻到员工账户中,查询员工账户的具体信息。故在设计的时候,我们需要定义如下字段:

loginUserId:当前登录者的userId;
loginUserRole:当前登录者的角色;
currentOptId:当前被操作者的账号(厂商id、门店id、员工userId);
currentOptRole:当前被操作者的角色;

登录者查询什么样的数据,查询的是被操作者账户的数据,而非登录者的信息,这样就可以实现下钻查询。

(2)和前端的交互设计:

这几个字段前端是否需要感知?我理解是不需要的,前端点击下钻/切换角色时,调用后端接口,后端将这些信息种植到cookie中,前端后续的请求将基于这些cookie,后端在解析这些cookie,从而定位到当前被操作者的信息

(3)多层下钻如何处理

在上面的设计中,只是保留了登录者userId和当前被操作者optId。但是会存在数据问题。举个例子

登录者:厂商管理员userId;
被操作者:员工A、子账户;

厂商管理员通过下钻门店C,在下钻到员工A(已离职)。

但是我们在参数中只能获取到员工账户。那么无法定位到当前查询的是员工A在门店C的数据,还是在门店B的数据。

故需要优化协议,将下钻的路径都记录下来,这样就可以实现精确查询。

loginUserId:当前登录者的userId;
loginUserRole:当前登录者的角色;‘
List<currentOptInfo> 当前被操作者的列表(下钻列表)

currentOptInfo:
  currentOptId:当前被操作者的账号(厂商id、门店id、员工userId);
  currentOptRole:当前被操作者的角色;

(4)下钻&切角色【终版设计】

在原有的设计中,登录者如何快速实现切换角色?直接覆盖loginUserRole字段即可。但是假设下钻后,肯定无法切换loginUserRole中的角色,那么我们如何实现呢?

切换角色本身可以是一种下钻,只不过下钻是逐层下钻,而切角色可以跳级切换。

假设用户是厂商管理员登录,cookie的格式

{
  "loginUserId":"登录者的userId",
  "loginUserRole":"1",
  "currentOptInfos":[{
    "currentOptId":"厂商id",
    "currentOptRole":"1"
   }
  ]
}

假设用户是厂商管理员登录,切换角色到子账户。
注意,此时前端会传子账户userId,但是后端种cookie的时候需要补全门店id

{
  "loginUserId":"登录者的userId",
  "loginUserRole":"1",
  "currentOptInfos":[{
    "currentOptId":"厂商id",
    "currentOptRole":"1"
  },{
    "currentOptId":"门店id",
    "currentOptRole":"2"
  },{
    "currentOptId":"员工userId",
    "currentOptRole":"3"
  }
  ]
}

假设用户是厂商管理员登录,切换到子账户后,有切换到厂商角色;
注意:需要进行回删,currentOptInfos只暴露一条数据;

{
  "loginUserId":"登录者的userId",
  "loginUserRole":"1",
  "currentOptInfos":[{
    "currentOptId":"厂商id",
    "currentOptRole":"1"
  }
  ]
}

假设用户是厂商管理员登录,切换到门店角色后,在下钻到员工B上;

{
  "loginUserId":"登录者的userId",
  "loginUserRole":"1",
  "currentOptInfos":[{
    "currentOptId":"厂商id",
    "currentOptRole":"1"
  },{
    "currentOptId":"门店id",
    "currentOptRole":"2"
  },{
    "currentOptId":"员工userId-B",
    "currentOptRole":"3"
  }
  ]
}

(5)权限控制

数据表中的记录是通过:【厂商id+门店id+员工userId】来作为唯一键确定一条记录,假设用户传递的组合不对,其实是查不到数据的。

唯一需要验证权限的是,当前登录者和被操作者(权限最大)是否有关系,例如:登录者的userId是否是门店的管理员?

上一篇 下一篇

猜你喜欢

热点阅读