FilterPermission.php 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. namespace app\v1\middleware;
  3. use plugin\saiadmin\app\cache\UserInfoCache;
  4. use Webman\Http\Request;
  5. use Webman\Http\Response;
  6. use Webman\MiddlewareInterface;
  7. /**
  8. * 权限检查中间件
  9. */
  10. class FilterPermission implements MiddlewareInterface
  11. {
  12. public function process(Request $request, callable $handler) : Response
  13. {
  14. // 获取请求方法
  15. $method = strtoupper($request->method());
  16. // 根据用户id获取用户权限
  17. $token = getCurrentInfo();
  18. // 用户权限缓存
  19. $userAuthCache = new UserInfoCache($token['id']);
  20. $user_info = $userAuthCache->getUserInfo();
  21. // 获取游戏数据权限
  22. $auth_game_list = $user_info['game_list'] ?? -1;
  23. // 获取游戏自然量数据权限
  24. $auth_normal_game_list = $user_info['normal_game_list'] ?? -1;
  25. // 获取游戏自然量数据权限
  26. $auth_ad_permission = $user_info['ad_permission'] ?? -1;
  27. // 追加参数逻辑
  28. $extraParams = [
  29. 'auth_normal_game_list' => $auth_normal_game_list === '*' ? '' : $auth_normal_game_list,
  30. 'auth_game_list' => $auth_game_list === '*' ? '' : $auth_game_list,
  31. 'auth_ad_permission' => $auth_ad_permission === '*' ? '' : $auth_ad_permission,
  32. ];
  33. // 合并并设置回 request
  34. if ($method === 'GET') {
  35. $request->setGet(array_merge($request->get(), $extraParams));
  36. } elseif ($method === 'POST') {
  37. $request->setPost(array_merge($request->post(), $extraParams));
  38. }
  39. return $handler($request);
  40. }
  41. }