Menu.php 6.9 KB

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