Menu.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Constants\HttpStatus;
  4. use App\Http\Controllers\Controller;
  5. use App\Services\MenuService;
  6. use Exception;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Validation\ValidationException;
  9. class Menu extends Controller
  10. {
  11. /**
  12. * @api {get} /admin/menu 菜单列表
  13. * @apiGroup 菜单管理
  14. * @apiUse result
  15. * @apiUse header
  16. * @apiVersion 1.0.0
  17. *
  18. * @apiParam {int} [page=1]
  19. * @apiParam {int} [limit=10]
  20. * @apiParam {string} [title] 菜单名称
  21. * @apiParam {int} [parent_id] 上级菜单
  22. * @apiParam {int} [type] 类型 1-菜单 2-按钮
  23. * @apiSuccess (data) {Object} data
  24. * @apiSuccess (data) {int} data.total 数量
  25. * @apiSuccess (data) {Object[]} data.data 列表
  26. * @apiSuccess (data) {int} data.data.id
  27. * @apiSuccess (data) {int} data.data.parent_id 上级菜单
  28. * @apiSuccess (data) {string} data.data.title 菜单名称
  29. * @apiSuccess (data) {string} data.data.uri 路由地址
  30. * @apiSuccess (data) {int} data.data.sort 排序标识
  31. * @apiSuccess (data) {string} data.data.updated_at
  32. * @apiSuccess (data) {string} data.data.created_at
  33. */
  34. public function index()
  35. {
  36. try {
  37. request()->validate([
  38. 'title' => ['nullable', 'string'],
  39. 'permission_name' => ['nullable', 'string'],
  40. ]);
  41. $search = request()->all();
  42. $result = MenuService::paginate($search);
  43. } catch (ValidationException $e) {
  44. return $this->error(HttpStatus::VALIDATION_FAILED, '', $e->validator->errors()->first());
  45. } catch (Exception $e) {
  46. return $this->error(intval($e->getCode()));
  47. }
  48. return $this->success($result);
  49. }
  50. /**
  51. * @api {post} /admin/menu/submit 修改菜单
  52. * @apiGroup 菜单管理
  53. *
  54. * @apiUse result
  55. * @apiUse header
  56. * @apiVersion 1.0.0
  57. *
  58. * @apiParam {int} id 菜单ID
  59. * @apiParam {string} title 菜单名称
  60. * @apiParam {string} [uri] 菜单链接地址/路由
  61. * @apiParam {string} [parent_id] 父级菜单ID
  62. * @apiParam {string} [sort] 排序值(越小越靠前)
  63. * @apiParam {string} [status] 状态 1-显示 2-隐藏
  64. * @apiParam {string} [type] 类型 1-菜单 2-按钮
  65. */
  66. public function store()
  67. {
  68. try {
  69. $params = request()->all();
  70. $validator = [
  71. 'title' => 'required|string|max:100',
  72. 'uri' => 'nullable|string|max:255',
  73. // 'icon' => 'nullable|string',
  74. // 'permission_name' => 'nullable|string|max:100',
  75. 'parent_id' => 'nullable|integer',
  76. 'status' => 'required|nullable|integer',
  77. 'type' => 'required|nullable|integer',
  78. 'sort' => 'required|nullable|integer',
  79. ];
  80. request()->validate($validator);
  81. $ret = MenuService::submit($params);
  82. if ($ret['code'] == MenuService::NOT) {
  83. return $this->error($ret['code'], $ret['msg']);
  84. }
  85. } catch (ValidationException $e) {
  86. return $this->error(HttpStatus::VALIDATION_FAILED, $e->validator->errors()->first());
  87. } catch (Exception $e) {
  88. return $this->error(intval($e->getCode()));
  89. }
  90. return $this->success([], $ret['msg']);
  91. }
  92. /**
  93. * @api {post} /admin/menu/delete 删除
  94. * @apiGroup 菜单管理
  95. *
  96. * @apiUse result
  97. * @apiUse header
  98. * @apiVersion 1.0.0
  99. *
  100. * @apiParam {int} id 菜单ID
  101. */
  102. public function destroy()
  103. {
  104. $id = request()->post('id');
  105. // 示例:通过 ID 删除菜单
  106. $info = MenuService::findOne(['id' => $id]);
  107. if (!$info) {
  108. return $this->error(0, '菜单不存在');
  109. }
  110. $info->delete();
  111. return $this->success([], '删除成功');
  112. }
  113. /**
  114. * @api {get} /admin/menu/all 全部菜单
  115. * @apiGroup 菜单管理
  116. *
  117. * @apiUse result
  118. * @apiUse header
  119. * @apiVersion 1.0.0
  120. *
  121. * @apiSuccess (data) {Object[]} data
  122. * @apiSuccess (data) {int} data.id 菜单ID
  123. * @apiSuccess (data) {int} data.parent_id 父级菜单ID
  124. * @apiSuccess (data) {string} data.title 菜单名称
  125. * @apiSuccess (data) {string} data.icon 菜单图标
  126. * @apiSuccess (data) {string} data.uri 菜单链接地址/路由
  127. * @apiSuccess (data) {string} data.type 类型 1-菜单 2-按钮
  128. * @apiSuccess (data) {string} data.status 状态 1-显示 2-隐藏
  129. * @apiSuccess (data) {int} data.sort 排序值(越小越靠前)
  130. *
  131. */
  132. public function all()
  133. {
  134. $search = request()->all();
  135. $result = MenuService::findAll($search);
  136. return $this->success($result);
  137. }
  138. /**
  139. * @api {get} /admin/menu/mineMenu 我的菜单
  140. * @apiGroup 菜单管理
  141. *
  142. * @apiUse result
  143. * @apiUse header
  144. * @apiVersion 1.0.0
  145. *
  146. * @apiSuccess (data) {Object[]} data
  147. * @apiSuccess (data) {int} data.id 菜单ID
  148. * @apiSuccess (data) {int} data.parent_id 父级菜单ID
  149. * @apiSuccess (data) {string} data.title 菜单名称
  150. * @apiSuccess (data) {string} data.icon 菜单图标
  151. * @apiSuccess (data) {string} data.uri 菜单链接地址/路由
  152. * @apiSuccess (data) {string} data.type 类型 1-菜单 2-按钮
  153. * @apiSuccess (data) {string} data.status 状态 1-显示 2-隐藏
  154. * @apiSuccess (data) {int} data.sort 排序值(越小越靠前)
  155. * @apiSuccess (data) {array} data.children 下级菜单
  156. *
  157. */
  158. public function mineMenu()
  159. {
  160. $userId = request()->user->id;
  161. $result = MenuService::getUserMenu($userId);
  162. return $this->success($result);
  163. }
  164. /**
  165. * @api {get} /admin/menu/tree 菜单按钮树
  166. * @apiGroup 菜单管理
  167. *
  168. * @apiUse result
  169. * @apiUse header
  170. * @apiVersion 1.0.0
  171. *
  172. * @apiSuccess (data) {Object[]} data
  173. * @apiSuccess (data) {int} data.id 菜单ID
  174. * @apiSuccess (data) {int} data.parent_id 父级菜单ID
  175. * @apiSuccess (data) {string} data.title 菜单名称
  176. * @apiSuccess (data) {string} data.icon 菜单图标
  177. * @apiSuccess (data) {string} data.uri 菜单链接地址/路由
  178. * @apiSuccess (data) {string} data.type 类型 1-菜单 2-按钮
  179. * @apiSuccess (data) {string} data.status 状态 1-显示 2-隐藏
  180. * @apiSuccess (data) {int} data.sort 排序值(越小越靠前)
  181. * @apiSuccess (data) {array} data.children 下级菜单
  182. *
  183. */
  184. public function tree()
  185. {
  186. $result = MenuService::getTree();
  187. return $this->success($result);
  188. }
  189. /**
  190. * @api {post} /admin/menu/check 接口权限校验
  191. * @apiGroup 菜单管理
  192. *
  193. * @apiUse result
  194. * @apiUse header
  195. * @apiVersion 1.0.0
  196. *
  197. * @apiParam {int} uri 接口地址 需要带admin 例子:admin/menu
  198. * @apiSuccess (data) {Object[]} data
  199. *
  200. */
  201. public function check()
  202. {
  203. $userId = request()->user->id;
  204. $uri = request()->post('uri','');
  205. $result = MenuService::checkMenu($userId,$uri);
  206. if($result){
  207. return $this->success($result, '有权限访问');
  208. }else{
  209. return $this->error(99,'没有权限访问',$result);
  210. }
  211. }
  212. }