截流自动化的商城平台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ShopAuthValidate.php 2.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeshop开源商城系统
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | gitee下载:https://gitee.com/likeshop_gitee
  7. // | github下载:https://github.com/likeshop-github
  8. // | 访问官网:https://www.likeshop.cn
  9. // | 访问社区:https://home.likeshop.cn
  10. // | 访问手册:http://doc.likeshop.cn
  11. // | 微信公众号:likeshop技术社区
  12. // | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
  13. // | likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
  14. // | 禁止对系统程序代码以任何目的,任何形式的再发布
  15. // | likeshop团队版权所有并拥有最终解释权
  16. // +----------------------------------------------------------------------
  17. // | author: likeshop.cn.team
  18. // +----------------------------------------------------------------------
  19. namespace app\admin\validate;
  20. use app\common\basics\Validate;
  21. use app\common\model\shop\ShopAuth;
  22. /**
  23. * 商家菜单
  24. * Class ShopAuthValidate
  25. * @package app\admin\validate
  26. */
  27. class ShopAuthValidate extends Validate
  28. {
  29. protected $rule = [
  30. 'name' => 'require',
  31. 'uri' => 'uri',
  32. 'type' => 'type',
  33. 'sort' => 'integer|between:1,1000'
  34. ];
  35. protected $message = [
  36. 'name.require' => '菜单名称不能为空',
  37. 'uri.uri' => '地址不存在',
  38. 'sort.integer' => '排序必须为正整数',
  39. 'sort.between' => '排序范围必须在1到1000之间',
  40. ];
  41. /**
  42. * url规则验证
  43. * @param $uri
  44. * @return bool
  45. */
  46. public function uri($uri)
  47. {
  48. if ($uri === '') {
  49. return true;
  50. }
  51. if (count(explode('/', $uri)) != 2) {
  52. return false;
  53. }
  54. return true;
  55. }
  56. /**
  57. * 类型验证
  58. * @param $type
  59. * @param $other
  60. * @param $data
  61. * @return bool|string
  62. */
  63. public function type($type, $other, $data)
  64. {
  65. if ($type == 2 && $data['pid'] == 0) {
  66. return '类型为权限的不能设置为顶级';
  67. }
  68. $data['id'] = empty($data['id']) ? 0 : $data['id'];
  69. $result = ShopAuth::where('id', '<>', $data['id'])
  70. ->where(['pid' => $data['pid'], 'del' => 0])
  71. ->value('type');
  72. if (!empty($result) && $result != $data['type']) {
  73. return '类型错误,必须设置与同一级一样';
  74. }
  75. return true;
  76. }
  77. }