AuthRule.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?php namespace App\Models\Manager;
  2. use Illuminate\Database\Eloquent\Factories\HasFactory;
  3. use Illuminate\Database\Eloquent\Model;
  4. /**
  5. * 权限组规则模型
  6. *
  7. */
  8. class AuthRule extends Model
  9. {
  10. use HasFactory;
  11. // 与模型关联的表名
  12. protected $table = 'auth_rule';
  13. // 是否主动维护时间戳
  14. public $timestamps = false;
  15. protected $connection = 'mysql';
  16. // 定义时间戳字段名
  17. // const CREATED_AT = 'insert_time';
  18. // const UPDATED_AT = 'update_time';
  19. /**
  20. * 添加数据
  21. *
  22. */
  23. public function add($data)
  24. {
  25. // 时间
  26. $data['insert_time'] = time();
  27. $data['update_time'] = time();
  28. // 写入数据表
  29. $id = $this->query()->insertGetId($data);
  30. // 如果操作失败
  31. if( !$id ) return 0;
  32. // 返回结果
  33. return $id;
  34. }
  35. /**
  36. * 添加数据
  37. *
  38. */
  39. public function edit($id,$data)
  40. {
  41. // 更新时间
  42. $data['update_time'] = time();
  43. // 写入数据表
  44. $result = $this->query()->where([['id','=',$id]])->update($data);
  45. // 如果操作失败
  46. if( !$result ) return 0;
  47. // 返回结果
  48. return $id;
  49. }
  50. /**
  51. * 获取列表
  52. * @param Bool $force 是否强制更新
  53. *
  54. */
  55. public function getList($groupId,$force = false)
  56. {
  57. // 结果数据
  58. $list = $force ? [] : cache('manager:auth:rule:list:'.$groupId);
  59. // 不存在数据
  60. if ( !$list ) {
  61. // 从数据库获取数据
  62. $data = $this->query()->where([['group_id','=',$groupId]])->get(['id','group_id','name','menu_id'])->toArray();
  63. // 循环处理数据
  64. $list = [];
  65. // 进行更新
  66. foreach ($data as $value) {
  67. // 重组数据
  68. $list[$value['id']] = $value;
  69. }
  70. // 存起来
  71. cache(['manager:auth:rule:list:'.$groupId=>$list]);
  72. }
  73. // 返回结果
  74. return $list;
  75. }
  76. /**
  77. * 获取配置平台对应的应用数据
  78. *
  79. * @param int 用户ID
  80. * @param string 指定字段
  81. *
  82. */
  83. public function getOne($groupId,$id,$field='')
  84. {
  85. // 获取列表数据
  86. $list = $this->getList($groupId,true);
  87. // 获取数据
  88. $one = isset($list[$id]) ? $list[$id] : [];
  89. // 返回值
  90. return empty($field) ? $one : ( isset($one[$field]) ? $one[$field] : null);
  91. }
  92. /**
  93. * 获得权限列表
  94. * @param integer $uid 用户id
  95. * @param integer $type
  96. */
  97. public function getAuthList($uid,$module='manager')
  98. {
  99. if( is_super($uid,$module) ){
  100. $rules = (new Menu)->getList($module,true);
  101. $rules = array_column($rules,'url');
  102. }else{
  103. $rules = (new AuthRule())->query()
  104. ->join('auth_group_access','auth_group_access.group_id','=','auth_rule.group_id')
  105. ->join('auth_group','auth_group.id','=','auth_rule.group_id')
  106. ->where([['auth_group_access.admin_uid','=',$uid],['auth_group.status','=',0]])
  107. ->pluck('auth_rule.name')->toArray();
  108. }
  109. // 循环转大写
  110. foreach ($rules as $key => $rule) {
  111. // 转小写,截除左边斜杠
  112. $value = ltrim(strtolower($rule), '/');
  113. if ($value != '') {
  114. $rules[$key] = $value;
  115. }
  116. }
  117. // 去重
  118. $rules = array_unique($rules);
  119. // 返回结果
  120. return $rules;
  121. }
  122. }