UserService.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  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\Http\Validator\MemberValidator;
  13. use App\Models\MemberModel;
  14. use App\Models\UserModel;
  15. use App\Services\BaseService;
  16. use App\Services\EmailService;
  17. use App\Services\SmsService;
  18. use App\Services\UsdtWalletService;
  19. use Earnp\GoogleAuthenticator\GoogleAuthenticator;
  20. /**
  21. * 用户管理-服务类
  22. * @author laravel开发员
  23. * @since 2020/11/11
  24. * Class UserService
  25. * @package App\Services\Common
  26. */
  27. class UserService extends BaseService
  28. {
  29. /**
  30. * 构造函数
  31. * @author laravel开发员
  32. * @since 2020/11/11
  33. * UserService constructor.
  34. */
  35. public function __construct()
  36. {
  37. $this->model = new UserModel();
  38. $this->memberModel = new MemberModel();
  39. }
  40. /**
  41. * 获取用户列表
  42. * @return array
  43. * @since 2020/11/11
  44. * @author laravel开发员
  45. */
  46. public function getList()
  47. {
  48. $param = request()->all();
  49. // 查询条件
  50. $map = [];
  51. // 用户账号
  52. $username = getter($param, "username");
  53. if ($username) {
  54. $map[] = ["username", 'like', "%{$username}%"];
  55. }
  56. // 用户姓名
  57. $realname = getter($param, "realname");
  58. if ($realname) {
  59. $map[] = ['realname', 'like', "%{$realname}%"];
  60. }
  61. // 用户性别
  62. $gender = getter($param, "gender");
  63. if ($gender) {
  64. $map[] = ['gender', '=', $gender];
  65. }
  66. // 用户类型
  67. $userType = getter($param, "user_type");
  68. if ($userType) {
  69. $map[] = ['user_type', '=', $userType];
  70. }
  71. return parent::getList($map); // TODO: Change the autogenerated stub
  72. }
  73. /**
  74. * 添加或编辑用户
  75. * @return array
  76. * @since 2020/11/11
  77. * @author laravel开发员
  78. */
  79. public function edit()
  80. {
  81. // 请求参数
  82. $data = request()->all();
  83. // 用户名
  84. $username = trim($data['username']);
  85. // 密码
  86. $password = trim($data['password']);
  87. // 添加时设置密码
  88. if (empty($data['id'])) {
  89. $data['password'] = get_password($password . md5($password.'otc'));
  90. // 用户名重复性验证
  91. $count = $this->model
  92. ->where("username", '=', $username)
  93. ->where("mark", "=", 1)
  94. ->count();
  95. if ($count > 0) {
  96. return message("系统中已存在相同的用户名", false);
  97. }
  98. } else {
  99. if($password){
  100. $data['password'] = get_password($password . md5($password.'otc'));
  101. }
  102. // 用户名重复性验证
  103. $count = $this->model
  104. ->where("username", '=', $username)
  105. ->where("id", "<>", $data['id'])
  106. ->where("mark", "=", 1)
  107. ->count();
  108. if ($count > 0) {
  109. return message("系统中已存在相同的用户名", false);
  110. }
  111. // 币商会员账号验证
  112. if($data['user_type'] == 2){
  113. // 用户名重复性验证
  114. $count = $this->memberModel
  115. ->where("username", '=', $username)
  116. ->where("id", "<>", $data['user_id'])
  117. ->where("mark", "=", 1)
  118. ->count();
  119. if ($count > 0) {
  120. return message("系统中已存在相同的会员账号", false);
  121. }
  122. }
  123. }
  124. // 头像处理
  125. $adminId = isset($data['id'])? $data['id'] : 0;
  126. $avatar = isset($data['avatar']) ? trim($data['avatar']) : '';
  127. if (strpos($avatar, "temp")) {
  128. $data['avatar'] = save_image($avatar, 'user');
  129. } else {
  130. $data['avatar'] = str_replace(IMG_URL, "", $data['avatar']);
  131. }
  132. $error = "";
  133. $data['birthday'] = isset($data['birthday'])? $data['birthday'] : '000-00-00';
  134. $data['bond'] = isset($data['bond'])? $data['bond'] : '0';
  135. $data['create_time'] = isset($data['create_time'])? $data['create_time'] : time();
  136. // 谷歌验证码
  137. if(empty($adminId) || empty($data['google_secret'])){
  138. $google = GoogleAuthenticator::CreateSecret();
  139. $data['google_secret'] = isset($google['secret'])? $google['secret'] : '';
  140. }
  141. $this->model->startTrans();
  142. $result = $this->model->edit($data, $error);
  143. if (!$result) {
  144. $this->model->rollBack();
  145. return message($error, false);
  146. }
  147. // 删除已存在的用户角色关系数据
  148. $userRoleService = new UserRoleService();
  149. $userRoleService->deleteUserRole($result);
  150. // 插入用户角色关系数据
  151. $userRoleService->insertUserRole($result, $data['role_ids']);
  152. // 新建币商会员账号
  153. $userId = isset($data['user_id'])? $data['user_id'] : 0;
  154. $ppassword = '123456';
  155. $data = [
  156. 'username'=> $username,
  157. 'realname'=> isset($data['realname'])? $data['realname'] : '',
  158. 'gender'=> isset($data['gender'])? $data['gender'] : 0,
  159. 'user_type'=> 2,
  160. 'mark'=> 1,
  161. 'status'=> 1,
  162. ];
  163. // 生成trc2.0钱包地址
  164. if(!$userId){
  165. $data['password'] = get_password($ppassword . md5($ppassword.'otc'));
  166. $trcAddress = UsdtWalletService::make()->getTrxAddress();
  167. if($trcAddress){
  168. $data['trc_wif'] = isset($trcAddress['wif'])? $trcAddress['wif'] : '';
  169. $data['trc_hexaddress'] = isset($trcAddress['hexAddress'])? $trcAddress['hexAddress'] : '';
  170. $data['trc_address'] = isset($trcAddress['address'])? $trcAddress['address'] : '';
  171. }else{
  172. $this->model->rollBack();
  173. return message('生成TRC钱包地址失败', false);
  174. }
  175. // 生erc2.0钱包地址
  176. $ercAddress = UsdtWalletService::make()->getErcAddress();
  177. if($trcAddress){
  178. $data['erc_wif'] = isset($ercAddress['wif'])? $ercAddress['wif'] : '';
  179. $data['erc_hexaddress'] = isset($ercAddress['hexAddress'])? $ercAddress['hexAddress'] : '';
  180. $data['erc_address'] = isset($ercAddress['address'])? $ercAddress['address'] : '';
  181. }else{
  182. $this->model->rollBack();
  183. return message('生成ERC钱包地址失败', false);
  184. }
  185. }
  186. $info = $this->memberModel->getInfo($userId);
  187. if($info){
  188. if(!$this->memberModel->where(['id'=> $userId])->update($data)){
  189. $this->model->rollBack();
  190. return message('修改交易员信息失败', false);
  191. }
  192. $this->model->commit();
  193. $this->model->where(['id'=> $adminId])->update(['user_id'=> $userId]);
  194. }else{
  195. if(!$userId = $this->memberModel->edit($data)){
  196. $this->model->rollBack();
  197. return message($userId? '修改交易员信息失败':'创建交易员账号失败', false);
  198. }
  199. $this->model->commit();
  200. // 更新绑定会员账号
  201. $this->model->where(['id'=> $result])->update(['user_id'=> $userId]);
  202. // 用户交易配置
  203. MemberSettingService::make()->getInfo($userId);
  204. }
  205. return message();
  206. }
  207. /**
  208. * 获取用户信息
  209. * @param $userId 用户ID
  210. * @return array
  211. * @author laravel开发员
  212. * @since 2020/11/10
  213. */
  214. public function getUserInfo($userId)
  215. {
  216. $userInfo = $this->model->getInfo($userId);
  217. $userInfo['roles'] = [];
  218. $userInfo['authorities'] = [];
  219. // 权限节点列表
  220. $menuService = new MenuService();
  221. $permissionList = $menuService->getPermissionsList($userId);
  222. $userInfo['permissionList'] = $permissionList;
  223. return message("操作成功", true, $userInfo);
  224. }
  225. /**
  226. * 更新个人资料
  227. * @author laravel开发员
  228. * @since 2020/11/11
  229. */
  230. public function updateUserInfo($userId)
  231. {
  232. // 参数
  233. $param = request()->all();
  234. // 个人信息
  235. $data = [
  236. 'id' => $userId,
  237. 'realname' => $param['realname'],
  238. 'nickname' => $param['nickname'],
  239. 'gender' => $param['gender'],
  240. 'mobile' => $param['mobile'],
  241. 'email' => $param['email'],
  242. 'intro' => $param['intro'],
  243. ];
  244. // 头像处理
  245. $avatar = isset($param['avatar']) ? $param['avatar'] : "";
  246. if (strpos($avatar, "data:image") !== false) {
  247. $expData = explode(';', $avatar);
  248. $fileInfo = explode('/', $expData[0]);
  249. $fileExt = $fileInfo[1] == 'jpeg' ? 'jpg' : $fileInfo[1];
  250. // 文件存储路径
  251. $filePath = create_image_path("user", $fileExt);
  252. // 获取图片流
  253. $item = explode(',', $avatar);
  254. file_put_contents(ATTACHMENT_PATH . $filePath, base64_decode($item[1]));
  255. $data['avatar'] = $filePath;
  256. } else {
  257. $data['avatar'] = str_replace(IMG_URL, "", $param['avatar']);
  258. }
  259. $result = $this->model->edit($data);
  260. if (!$result) {
  261. return message("更新资料信息失败", false);
  262. }
  263. return message("更新资料信息成功");
  264. }
  265. /**
  266. * 更新密码
  267. * @param $userId 用户ID
  268. * @return array
  269. * @author laravel开发员
  270. * @since 2020/11/14
  271. */
  272. public function updatePwd($userId)
  273. {
  274. // 获取参数
  275. $param = request()->all();
  276. // 原始密码
  277. $oldPassword = trim(getter($param, "oldPassword"));
  278. if (!$oldPassword) {
  279. return message("旧密码不能为空", false);
  280. }
  281. // 新密码
  282. $newPassword = trim(getter($param, "newPassword"));
  283. if (!$newPassword) {
  284. return message("新密码不能为空", false);
  285. }
  286. $userInfo = $this->model->getInfo($userId);
  287. if (!$userInfo) {
  288. return message("用户信息不存在", false);
  289. }
  290. if ($userInfo['password'] != get_password($oldPassword . md5($oldPassword.'otc'))) {
  291. return message("旧密码输入不正确", false);
  292. }
  293. // 设置新密码
  294. $userInfo['password'] = get_password($newPassword . md5($newPassword.'otc'));
  295. $result = $this->model->edit($userInfo);
  296. if (!$result) {
  297. return message("修改失败", false);
  298. }
  299. return message("修改成功");
  300. }
  301. /**
  302. * 更新交易密码
  303. * @param $userId 用户ID
  304. * @param $adminId 管理ID
  305. * @return array
  306. * @author laravel开发员
  307. * @since 2020/11/14
  308. */
  309. public function updateTradePwd($userId, $adminId)
  310. {
  311. // 获取参数
  312. $param = request()->all();
  313. // 原始密码
  314. $loginPassword = trim(getter($param, "loginPassword"));
  315. if (!$loginPassword) {
  316. return message("登录密码不能为空", false);
  317. }
  318. // 新密码
  319. $newPassword = trim(getter($param, "newPassword"));
  320. if (!$newPassword) {
  321. return message("新密码不能为空", false);
  322. }
  323. $userInfo = $this->model->getInfo($adminId);
  324. $memberInfo = MemberService::make()->getInfo($userId);
  325. if (!$userInfo || empty($memberInfo)) {
  326. return message("用户信息不存在", false);
  327. }
  328. if ($userInfo['password'] != get_password($loginPassword . md5($loginPassword.'otc'))) {
  329. return message("登录密码输入不正确", false);
  330. }
  331. // 设置新密码
  332. $password = get_password($newPassword . md5($newPassword.'otc'));
  333. $result = $this->memberModel->where(['id'=> $userId])->update(['trade_password'=> $password]);
  334. if (!$result) {
  335. return message("交易密码更新设置失败", false);
  336. }
  337. return message("交易密码更新设置成功");
  338. }
  339. /**
  340. * 更新谷歌验证码
  341. * @param $userId 用户ID
  342. * @return array
  343. */
  344. public function updateGoogle($userId)
  345. {
  346. // 获取参数
  347. $param = request()->all();
  348. // 验证码
  349. $code = trim(getter($param, "code"));
  350. $username = trim(getter($param, "username"));
  351. if(empty($username)){
  352. return message("账号参数错误", false);
  353. }
  354. if (!$code) {
  355. return message("验证码不能为空", false);
  356. }
  357. // 验证码
  358. $validator = new MemberValidator();
  359. if(!is_array($validator->check(['mobile'=> $username],'mobile'))){
  360. if(!EmailService::make()->check($username, $code, 'google')){
  361. return message(EmailService::make()->getError(), false);
  362. }
  363. }else{
  364. if(!SmsService::make()->check($username, $code, 'google')){
  365. return message(SmsService::make()->getError(), false);
  366. }
  367. }
  368. //
  369. $googleCode = trim(getter($param, "google_code"));
  370. if (!$googleCode) {
  371. return message("谷歌验证码不能为空", false);
  372. }
  373. $userInfo = $this->model->getInfo($userId);
  374. if (!$userInfo) {
  375. return message("用户信息不存在", false);
  376. }
  377. // 谷歌验证码
  378. $googleSecret = isset($userInfo['google_secret'])? $userInfo['google_secret'] : '';
  379. if(empty($googleSecret)){
  380. return message("您尚未绑定谷歌验证码", false);
  381. }
  382. if (!GoogleAuthenticator::CheckCode($googleSecret, $googleCode)) {
  383. return message("谷歌验证码错误", false);
  384. }
  385. // 设置新谷歌验证码
  386. $google = GoogleAuthenticator::CreateSecret();
  387. $googleSecret = isset($google['secret'])? $google['secret'] : '';
  388. $result = $this->model->where(['id'=> $userId])->update(['google_secret'=> $googleSecret,'google_verify_time'=> time() + 86400]);
  389. if (!$result) {
  390. return message("谷歌验证码更新设置失败", false);
  391. }
  392. return message("谷歌验证码更新设置成功");
  393. }
  394. /**
  395. * 重置密码
  396. * @return array
  397. * @since 2020/11/14
  398. * @author laravel开发员
  399. */
  400. public function resetPwd()
  401. {
  402. // 获取参数
  403. $param = request()->all();
  404. // 用户ID
  405. $userId = getter($param, "id");
  406. if (!$userId) {
  407. return message("用户ID不能为空", false);
  408. }
  409. $userInfo = $this->model->getInfo($userId);
  410. if (!$userInfo) {
  411. return message("用户信息不存在", false);
  412. }
  413. // 设置新密码
  414. $userInfo['password'] = get_password("123456" . md5('123456'.'otc'));
  415. $result = $this->model->edit($userInfo);
  416. if (!$result) {
  417. return message("重置密码失败", false);
  418. }
  419. return message("重置密码成功");
  420. }
  421. }