MerchantAdmin.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\controller\admin\system\merchant;
  12. use crmeb\basic\BaseController;
  13. use app\common\repositories\system\merchant\MerchantAdminRepository;
  14. use app\validate\admin\AdminValidate;
  15. use FormBuilder\Exception\FormBuilderException;
  16. use think\App;
  17. use think\db\exception\DbException;
  18. /**
  19. * 商户管理员
  20. */
  21. class MerchantAdmin extends BaseController
  22. {
  23. /**
  24. * @var MerchantAdminRepository
  25. */
  26. protected $repository;
  27. /**
  28. * MerchantAdmin constructor.
  29. * @param App $app
  30. * @param MerchantAdminRepository $repository
  31. */
  32. public function __construct(App $app, MerchantAdminRepository $repository)
  33. {
  34. parent::__construct($app);
  35. $this->repository = $repository;
  36. }
  37. /**
  38. * 修改密码表单
  39. * @param int $id
  40. * @return mixed
  41. * @throws FormBuilderException
  42. * @author xaboy
  43. * @day 2020-04-17
  44. */
  45. public function passwordForm($id)
  46. {
  47. return app('json')->success(formToData($this->repository->passwordForm($id, 1)));
  48. }
  49. /**
  50. * 修改商户顶级管理员密码
  51. * @param int $id
  52. * @param AdminValidate $validate
  53. * @return mixed
  54. * @throws DbException
  55. * @author xaboy
  56. * @day 2020-04-17
  57. */
  58. public function password($id, AdminValidate $validate)
  59. {
  60. $data = $this->request->params(['pwd', 'againPassword']);
  61. $validate->isPassword()->check($data);
  62. if ($data['pwd'] !== $data['againPassword'])
  63. return app('json')->fail('两次密码输入不一致');
  64. $adminId = $this->repository->merchantIdByTopAdminId($id);
  65. if (!$adminId)
  66. return app('json')->fail('商户不存在');
  67. $data['pwd'] = $this->repository->passwordEncode($data['pwd']);
  68. unset($data['againPassword']);
  69. $this->repository->update($adminId, $data);
  70. return app('json')->success('修改密码成功');
  71. }
  72. }