MerchantAuthMiddleware.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\common\middleware;
  12. use app\common\repositories\system\auth\MenuRepository;
  13. use app\common\repositories\system\auth\RoleRepository;
  14. use app\Request;
  15. use think\exception\ValidateException;
  16. use think\Response;
  17. class MerchantAuthMiddleware extends BaseMiddleware
  18. {
  19. public function before(Request $request)
  20. {
  21. $admin = $request->adminInfo();
  22. $merchant = $request->merchant();
  23. /** @var RoleRepository $role */
  24. $role = app()->make(RoleRepository::class);
  25. /** @var MenuRepository $menu */
  26. $menu = app()->make(MenuRepository::class);
  27. if ($admin->level) {
  28. $rules = $role->idsByRules($request->merId(), $admin->roles);
  29. $menus = count($rules) ? ($merchant->type_id ? $menu->typesByRoutes($merchant->type_id, $rules) : $menu->idsByRoutes($rules)) : [];
  30. $msg = '没有权限访问';
  31. } else {
  32. $rules = [];
  33. $menus = $merchant->type_id ? $menu->merchantTypeByRoutes($merchant->type_id) : [];
  34. $msg = '请前往平台后台-商户 - 店铺管理 - 店铺类型-编辑店铺权限';
  35. }
  36. $request->macro('adminAuth', function () use (&$menus) {
  37. return $menus;
  38. });
  39. $request->macro('adminRule', function () use (&$rules) {
  40. return $rules;
  41. });
  42. $request->macro('checkAuth', function ($name, $vars) use (&$merchant, &$admin, &$menus, &$menu) {
  43. if (!$name || (!$admin->level && !$merchant->type_id)) return true;
  44. $isset = false;
  45. foreach ($menus as $_menu) {
  46. $keys = $menu->tidyParams($_menu['params']);
  47. if ($_menu['route'] != $name) continue;
  48. $isset = true;
  49. if (!count($keys)) return true;
  50. if ($menu->checkParams($keys, $vars))
  51. return true;
  52. }
  53. if ($isset || $menu->routeExists($name, 1))
  54. return false;
  55. return true;
  56. });
  57. $rule = $request->rule();
  58. if (!$rule) {
  59. return true;
  60. }
  61. $options = $rule->getOption();
  62. if (!($options['_auth'] ?? true) && !isset($options['_form'])) {
  63. return true;
  64. }
  65. if (isset($options['_form'])) {
  66. $name = $options['_form'];
  67. $var = $options['_form_val'] ?? [];
  68. } else {
  69. $name = $rule->getName();
  70. $var = $rule->getVars();
  71. }
  72. if (!$request->checkAuth($name, $var))
  73. throw new ValidateException($msg);
  74. }
  75. public function after(Response $response)
  76. {
  77. // TODO: Implement after() method.
  78. }
  79. }