UserService.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | LARAVEL8.0 框架 [ LARAVEL ][ RXThinkCMF ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 LARAVEL研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: laravel开发员 <laravel.qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Services\Common;
  12. use App\Models\MemberModel;
  13. use App\Models\UserModel;
  14. use App\Services\BaseService;
  15. use App\Services\UsdtWalletService;
  16. /**
  17. * 用户管理-服务类
  18. * @author laravel开发员
  19. * @since 2020/11/11
  20. * Class UserService
  21. * @package App\Services\Common
  22. */
  23. class UserService extends BaseService
  24. {
  25. /**
  26. * 构造函数
  27. * @author laravel开发员
  28. * @since 2020/11/11
  29. * UserService constructor.
  30. */
  31. public function __construct()
  32. {
  33. $this->model = new UserModel();
  34. $this->memberModel = new MemberModel();
  35. }
  36. /**
  37. * 获取用户列表
  38. * @return array
  39. * @since 2020/11/11
  40. * @author laravel开发员
  41. */
  42. public function getList()
  43. {
  44. $param = request()->all();
  45. // 查询条件
  46. $map = [];
  47. // 用户账号
  48. $username = getter($param, "username");
  49. if ($username) {
  50. $map[] = ["username", 'like', "%{$username}%"];
  51. }
  52. // 用户姓名
  53. $realname = getter($param, "realname");
  54. if ($realname) {
  55. $map[] = ['realname', 'like', "%{$realname}%"];
  56. }
  57. // 用户性别
  58. $gender = getter($param, "gender");
  59. if ($gender) {
  60. $map[] = ['gender', '=', $gender];
  61. }
  62. // 用户类型
  63. $userType = getter($param, "user_type");
  64. if ($userType) {
  65. $map[] = ['user_type', '=', $userType];
  66. }
  67. return parent::getList($map); // TODO: Change the autogenerated stub
  68. }
  69. /**
  70. * 添加或编辑用户
  71. * @return array
  72. * @since 2020/11/11
  73. * @author laravel开发员
  74. */
  75. public function edit()
  76. {
  77. // 请求参数
  78. $data = request()->all();
  79. // 用户名
  80. $username = trim($data['username']);
  81. // 密码
  82. $password = trim($data['password']);
  83. // 添加时设置密码
  84. if (empty($data['id'])) {
  85. $data['password'] = get_password($password . $username);
  86. // 用户名重复性验证
  87. $count = $this->model
  88. ->where("username", '=', $username)
  89. ->where("mark", "=", 1)
  90. ->count();
  91. if ($count > 0) {
  92. return message("系统中已存在相同的用户名", false);
  93. }
  94. } else {
  95. if($password){
  96. $data['password'] = get_password($password . $username);
  97. }
  98. // 用户名重复性验证
  99. $count = $this->model
  100. ->where("username", '=', $username)
  101. ->where("id", "<>", $data['id'])
  102. ->where("mark", "=", 1)
  103. ->count();
  104. if ($count > 0) {
  105. return message("系统中已存在相同的用户名", false);
  106. }
  107. // 币商会员账号验证
  108. if($data['user_type'] == 2){
  109. // 用户名重复性验证
  110. $count = $this->memberModel
  111. ->where("username", '=', $username)
  112. ->where("id", "<>", $data['user_id'])
  113. ->where("mark", "=", 1)
  114. ->count();
  115. if ($count > 0) {
  116. return message("系统中已存在相同的会员账号", false);
  117. }
  118. }
  119. }
  120. // 头像处理
  121. $adminId = isset($data['id'])? $data['id'] : 0;
  122. $avatar = isset($data['avatar']) ? trim($data['avatar']) : '';
  123. if (strpos($avatar, "temp")) {
  124. $data['avatar'] = save_image($avatar, 'user');
  125. } else {
  126. $data['avatar'] = str_replace(IMG_URL, "", $data['avatar']);
  127. }
  128. $error = "";
  129. $data['birthday'] = isset($data['birthday'])? $data['birthday'] : '000-00-00';
  130. $data['create_time'] = isset($data['create_time'])? $data['create_time'] : time();
  131. $result = $this->model->edit($data, $error);
  132. if (!$result) {
  133. return message($error, false);
  134. }
  135. // 删除已存在的用户角色关系数据
  136. $userRoleService = new UserRoleService();
  137. $userRoleService->deleteUserRole($result);
  138. // 插入用户角色关系数据
  139. $userRoleService->insertUserRole($result, $data['role_ids']);
  140. // 新建币商会员账号
  141. $userId = isset($data['user_id'])? $data['user_id'] : 0;
  142. $ppassword = isset($data['ppassword'])? trim($data['ppassword']) : '';
  143. $data = [
  144. 'username'=> $username,
  145. 'realname'=> isset($data['realname'])? $data['realname'] : '',
  146. 'gender'=> isset($data['gender'])? $data['gender'] : 0,
  147. 'user_type'=> 2,
  148. 'mark'=> 1,
  149. 'status'=> 1,
  150. ];
  151. // 生成trc2.0钱包地址
  152. if(!$userId){
  153. $data['password'] = get_password($ppassword . $username);
  154. $trcAddress = UsdtWalletService::make()->getTrxAddress();
  155. if($trcAddress){
  156. $data['trc_wif'] = isset($trcAddress['wif'])? $trcAddress['wif'] : '';
  157. $data['trc_hexaddress'] = isset($trcAddress['hexAddress'])? $trcAddress['hexAddress'] : '';
  158. $data['trc_address'] = isset($trcAddress['address'])? $trcAddress['address'] : '';
  159. }else{
  160. return message('生成TRC钱包地址失败', false);
  161. }
  162. // 生erc2.0钱包地址
  163. $ercAddress = UsdtWalletService::make()->getErcAddress();
  164. if($trcAddress){
  165. $data['erc_wif'] = isset($ercAddress['wif'])? $ercAddress['wif'] : '';
  166. $data['erc_hexaddress'] = isset($ercAddress['hexAddress'])? $ercAddress['hexAddress'] : '';
  167. $data['erc_address'] = isset($ercAddress['address'])? $ercAddress['address'] : '';
  168. }else{
  169. return message('生成ERC钱包地址失败', false);
  170. }
  171. }
  172. $info = $this->memberModel->getInfo($userId);
  173. if($info){
  174. if(!$this->memberModel->where(['id'=> $userId])->update($data)){
  175. return message('修改币商会员信息失败', false);
  176. }
  177. }else{
  178. if(!$userId = $this->memberModel->edit($data)){
  179. return message($userId? '修改币商会员信息失败':'创建币商会员账号失败', false);
  180. }
  181. // 更新绑定会员账号
  182. $this->model->where(['id'=> $adminId])->update(['user_id'=> $userId]);
  183. // 用户交易配置
  184. MemberSettingService::make()->getInfo($userId);
  185. }
  186. return message();
  187. }
  188. /**
  189. * 获取用户信息
  190. * @param $userId 用户ID
  191. * @return array
  192. * @author laravel开发员
  193. * @since 2020/11/10
  194. */
  195. public function getUserInfo($userId)
  196. {
  197. $userInfo = $this->model->getInfo($userId);
  198. $userInfo['roles'] = [];
  199. $userInfo['authorities'] = [];
  200. // 权限节点列表
  201. $menuService = new MenuService();
  202. $permissionList = $menuService->getPermissionsList($userId);
  203. $userInfo['permissionList'] = $permissionList;
  204. return message("操作成功", true, $userInfo);
  205. }
  206. /**
  207. * 更新个人资料
  208. * @author laravel开发员
  209. * @since 2020/11/11
  210. */
  211. public function updateUserInfo($userId)
  212. {
  213. // 参数
  214. $param = request()->all();
  215. // 个人信息
  216. $data = [
  217. 'id' => $userId,
  218. 'realname' => $param['realname'],
  219. 'nickname' => $param['nickname'],
  220. 'gender' => $param['gender'],
  221. 'mobile' => $param['mobile'],
  222. 'email' => $param['email'],
  223. 'intro' => $param['intro'],
  224. ];
  225. // 头像处理
  226. $avatar = isset($param['avatar']) ? $param['avatar'] : "";
  227. if (strpos($avatar, "data:image") !== false) {
  228. $expData = explode(';', $avatar);
  229. $fileInfo = explode('/', $expData[0]);
  230. $fileExt = $fileInfo[1] == 'jpeg' ? 'jpg' : $fileInfo[1];
  231. // 文件存储路径
  232. $filePath = create_image_path("user", $fileExt);
  233. // 获取图片流
  234. $item = explode(',', $avatar);
  235. file_put_contents(ATTACHMENT_PATH . $filePath, base64_decode($item[1]));
  236. $data['avatar'] = $filePath;
  237. } else {
  238. $data['avatar'] = str_replace(IMG_URL, "", $param['avatar']);
  239. }
  240. $result = $this->model->edit($data);
  241. if (!$result) {
  242. return message("更新资料信息失败", false);
  243. }
  244. return message("更新资料信息成功");
  245. }
  246. /**
  247. * 更新密码
  248. * @param $userId 用户ID
  249. * @return array
  250. * @author laravel开发员
  251. * @since 2020/11/14
  252. */
  253. public function updatePwd($userId)
  254. {
  255. // 获取参数
  256. $param = request()->all();
  257. // 原始密码
  258. $oldPassword = trim(getter($param, "oldPassword"));
  259. if (!$oldPassword) {
  260. return message("旧密码不能为空", false);
  261. }
  262. // 新密码
  263. $newPassword = trim(getter($param, "newPassword"));
  264. if (!$newPassword) {
  265. return message("新密码不能为空", false);
  266. }
  267. $userInfo = $this->model->getInfo($userId);
  268. if (!$userInfo) {
  269. return message("用户信息不存在", false);
  270. }
  271. if ($userInfo['password'] != get_password($oldPassword . $userInfo['username'])) {
  272. return message("旧密码输入不正确", false);
  273. }
  274. // 设置新密码
  275. $userInfo['password'] = get_password($newPassword . $userInfo['username']);
  276. $result = $this->model->edit($userInfo);
  277. if (!$result) {
  278. return message("修改失败", false);
  279. }
  280. return message("修改成功");
  281. }
  282. /**
  283. * 重置密码
  284. * @return array
  285. * @since 2020/11/14
  286. * @author laravel开发员
  287. */
  288. public function resetPwd()
  289. {
  290. // 获取参数
  291. $param = request()->all();
  292. // 用户ID
  293. $userId = getter($param, "id");
  294. if (!$userId) {
  295. return message("用户ID不能为空", false);
  296. }
  297. $userInfo = $this->model->getInfo($userId);
  298. if (!$userInfo) {
  299. return message("用户信息不存在", false);
  300. }
  301. // 设置新密码
  302. $userInfo['password'] = get_password("123456" . $userInfo['username']);
  303. $result = $this->model->edit($userInfo);
  304. if (!$result) {
  305. return message("重置密码失败", false);
  306. }
  307. return message("重置密码成功");
  308. }
  309. }