UserService.php 16 KB

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