AdminController.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. <?php
  2. namespace App\Http\Controllers\Admin\Base;
  3. use App\Contracts\Repositories\Base\AdminRepository;
  4. use App\Http\Controllers\Controller;
  5. use App\Jobs\Base\ImportAdminJob;
  6. use App\Repositories\Enums\ResponseCodeEnum;
  7. use App\Repositories\Models\Base\Admin;
  8. use App\Repositories\Models\Base\Resource;
  9. use Illuminate\Http\Request;
  10. use Illuminate\Support\Facades\Hash;
  11. use Jiannei\Response\Laravel\Support\Facades\Response;
  12. use Prettus\Validator\Contracts\ValidatorInterface;
  13. use App\Repositories\Validators\Base\AdminValidator;
  14. /**
  15. * Class AdminsController.
  16. *
  17. * @package namespace App\Http\Controllers;
  18. */
  19. class AdminController extends Controller
  20. {
  21. /**
  22. * @var AdminRepository
  23. */
  24. protected $repository;
  25. /**
  26. * @var AdminValidator
  27. */
  28. protected $validator;
  29. /**
  30. * AdminsController constructor.
  31. *
  32. * @param AdminRepository $repository
  33. * @param AdminValidator $validator
  34. */
  35. public function __construct(AdminRepository $repository, AdminValidator $validator)
  36. {
  37. parent::__construct();
  38. $this->repository = $repository;
  39. $this->validator = $validator;
  40. }
  41. /**
  42. * 列表
  43. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  44. * Author: Mead
  45. */
  46. public function index()
  47. {
  48. $lists = $this->repository->paginate(request('per_page', self::PAGE_NUM));
  49. return Response::success($lists);
  50. }
  51. /**
  52. * 创建用户
  53. * @param Request $request
  54. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource|void
  55. * @throws \Illuminate\Validation\ValidationException
  56. * Author: Mead
  57. */
  58. public function store(Request $request)
  59. {
  60. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_CREATE));
  61. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_CREATE)));
  62. if ($msg = check_password($data['password'])) {
  63. return Response::fail($msg);
  64. }
  65. if ($data['password']) {
  66. $data['password'] = Hash::make($data['password']);
  67. }
  68. $role_ids = $data['role_ids'];
  69. unset($data['role_ids']);
  70. if (in_array(2, $role_ids) || in_array(3, $role_ids)) {
  71. $this->validate($request, [
  72. 'department_id' => 'required|integer'
  73. ]);
  74. }
  75. try {
  76. $model = Admin::query()->create($data);
  77. if (count($role_ids)) {
  78. $model->syncRoles($role_ids);
  79. }
  80. return Response::success($model);
  81. } catch (\Exception $e) {
  82. return $this->error($e);
  83. }
  84. }
  85. /**
  86. * 详情
  87. * @param $id
  88. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  89. * Author: Mead
  90. */
  91. public function show($id)
  92. {
  93. $patient = $this->repository->find($id);
  94. return Response::success($patient);
  95. }
  96. /**
  97. * 修改
  98. * @param Request $request
  99. * @param $id
  100. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  101. * @throws \Illuminate\Validation\ValidationException
  102. * Author: Mead
  103. */
  104. public function update(Request $request, $id)
  105. {
  106. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_UPDATE));
  107. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_UPDATE)));
  108. if (isset($data['password']) && !is_null($data['password'])) {
  109. if ($msg = check_password($data['password'])) {
  110. return Response::fail($msg);
  111. }
  112. $data['password'] = Hash::make($data['password']);
  113. } else {
  114. unset($data['password']);
  115. }
  116. $model = Admin::query()->where('id', $id)->first();
  117. $role_ids = $data['role_ids'];
  118. if (in_array(2, $role_ids) || in_array(3, $role_ids)) {
  119. $this->validate($request, [
  120. 'department_id' => 'required|integer'
  121. ]);
  122. }
  123. unset($data['role_ids']);
  124. if (count($role_ids)) {
  125. $model->syncRoles($role_ids);
  126. }
  127. $model->fill($data);
  128. $re = $model->save();
  129. if ($re) {
  130. return Response::success(null);
  131. }
  132. return $this->errorFail();
  133. }
  134. /**
  135. * 删除
  136. * @param $id
  137. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  138. * Author: Mead
  139. */
  140. public function destroy($id)
  141. {
  142. try {
  143. $re = $this->repository->delete($id);
  144. if ($re) {
  145. return Response::success(null, T('successfully delete.'));
  146. }
  147. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  148. } catch (\Exception $exception) {
  149. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  150. }
  151. }
  152. /**
  153. * 用户授权
  154. * @param Request $request
  155. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  156. * @throws \Illuminate\Validation\ValidationException
  157. * Author: Mead
  158. */
  159. public function authorization(Request $request)
  160. {
  161. $this->validate($request, [
  162. 'id' => 'required|integer',
  163. 'role_ids' => 'required|array',
  164. ]);
  165. $model = Admin::query()->find($request->get('id'));
  166. if (!$model) {
  167. return Response::fail('找不到该用户');
  168. }
  169. $role_ids = $request->get('role_ids');
  170. $model->syncRoles($role_ids);
  171. return Response::success(null);
  172. }
  173. /**
  174. * 选项列表
  175. * @param Request $request
  176. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  177. */
  178. public function selectOptions(Request $request)
  179. {
  180. $admins = $this->repository->select(['id', 'username', 'name'])->get();
  181. return Response::success($admins);
  182. }
  183. /**
  184. * 重置密码
  185. * @param Request $request
  186. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  187. * @throws \Illuminate\Validation\ValidationException
  188. */
  189. public function changePassword(Request $request)
  190. {
  191. $this->validate($request, [
  192. 'id' => 'required|integer',
  193. 'password' => 'required',
  194. ]);
  195. $id = $request->get('id');
  196. $password = $request->get('password');
  197. if ($msg = check_password($password)) {
  198. return Response::fail($msg);
  199. }
  200. $admin = Admin::query()->find($id);
  201. if (!$admin) {
  202. return Response::fail('找不到该用户');
  203. }
  204. $admin->password = Hash::make($password);
  205. $admin->save();
  206. return Response::success([]);
  207. }
  208. /**
  209. * 导入
  210. * @param Request $request
  211. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  212. * @throws \Illuminate\Validation\ValidationException
  213. * Author: Mead
  214. */
  215. public function import(Request $request)
  216. {
  217. $this->validate($request, [
  218. 'id' => 'required|integer'
  219. ]);
  220. $resource = Resource::query()->where('id', $request->get('id'))->first();
  221. if (!$resource) {
  222. return $this->errorFail();
  223. }
  224. $this->dispatch(new ImportAdminJob($resource['disk'], $resource['path']));
  225. return Response::success(null, '正在导入,请稍后');
  226. }
  227. }