package com.example.erp.config; import cn.dev33.satoken.stp.StpInterface; import com.example.erp.service.userInfo.PermissionRoleService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.List; /** * 自定义权限认证接口扩展,Sa-Token 将从此实现类获取每个账号拥有的权限码 * * @author kong * @since 2022-10-13 */ @Component // 打开此注解,保证此类被springboot扫描,即可完成sa-token的自定义权限验证扩展 public class StpInterfaceImpl implements StpInterface { private final PermissionRoleService permissionRoleService; public StpInterfaceImpl(PermissionRoleService permissionRoleService) { this.permissionRoleService = permissionRoleService; } /** * 返回一个账号所拥有的权限码集合 */ @Override public List getPermissionList(Object loginId, String loginType) { // 本list仅做模拟,实际项目中要根据具体业务逻辑来查询权限 /*List list = new ArrayList<>(); list.add("101"); list.add("user.add"); list.add("user.update"); list.add("user.get"); // list.add("user.delete"); list.add("art.*");*/ return permissionRoleService.getUserPermission(Integer.parseInt((String) loginId)); } /** * 返回一个账号所拥有的角色标识集合 */ @Override public List getRoleList(Object loginId, String loginType) { return permissionRoleService.getUserRole(Integer.parseInt((String) loginId)); } }