User.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Constants\HttpStatus;
  4. use App\Http\Controllers\Controller;
  5. use App\Services\SecretService;
  6. use App\Services\TopUpService;
  7. use Illuminate\Support\Facades\App;
  8. use Illuminate\Support\Facades\DB;
  9. use App\Services\UserService;
  10. use Exception;
  11. use Illuminate\Validation\ValidationException;
  12. use App\Services\AddressService;
  13. use Illuminate\Http\JsonResponse;
  14. use App\Models\User as UserModel;
  15. use App\Models\UserSession;
  16. use App\Models\UserLogin;
  17. use Illuminate\Support\Facades\Cache;
  18. class User extends Controller
  19. {
  20. //修改用户密码/资金密码
  21. function setPassword()
  22. {
  23. try {
  24. $params = request()->validate([
  25. 'member_id' => ['required', 'string', 'min:1'],
  26. 'password' => ['nullable'],
  27. 'payment_password' => ['nullable'],
  28. ]);
  29. $user = UserModel::where('member_id', $params['member_id'])->first();
  30. if (!$user) throw new Exception("用户不存在", HttpStatus::CUSTOM_ERROR);
  31. if (!empty($params['password'])) {
  32. $user->password = create_password($params['password']);
  33. $user->save();
  34. //删除缓存
  35. $token = UserSession::where('user_id', $params['member_id'])->orderByDesc('expire_time')->value('token');
  36. Cache::delete('token_user_' . $token);
  37. UserSession::where('user_id', $params['member_id'])->delete();
  38. }
  39. if (!empty($params['payment_password'])) {
  40. $user->payment_password = password_hash($params['payment_password'], PASSWORD_DEFAULT);
  41. $user->save();
  42. }
  43. } catch (ValidationException $e) {
  44. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  45. } catch (Exception $e) {
  46. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  47. }
  48. return $this->success();
  49. }
  50. function banned()
  51. {
  52. try {
  53. $params = request()->validate([
  54. 'member_id' => ['required', 'string', 'min:1'],
  55. 'is_banned' => ['required', 'integer', 'in:0,1'],
  56. ]);
  57. UserModel::where('member_id', $params['member_id'])->update(['is_banned' => $params['is_banned']]);
  58. if ($params['is_banned'] == 1) {
  59. //如果用户被禁用,删除所有会话
  60. UserSession::where('user_id', $params['member_id'])->delete();
  61. return $this->success();
  62. }
  63. } catch (ValidationException $e) {
  64. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  65. } catch (Exception $e) {
  66. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  67. }
  68. return $this->success();
  69. }
  70. function setNote()
  71. {
  72. try {
  73. $params = request()->validate([
  74. 'member_id' => ['required', 'string', 'min:1'],
  75. 'admin_note' => ['required', 'string', 'min:1', 'max:120'],
  76. ]);
  77. $user = UserModel::where('member_id', $params['member_id'])->first();
  78. if (!$user) throw new Exception("用户不存在", HttpStatus::CUSTOM_ERROR);
  79. $user->admin_note = $params['admin_note'];
  80. $user->save();
  81. } catch (ValidationException $e) {
  82. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  83. } catch (Exception $e) {
  84. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  85. }
  86. return $this->success();
  87. }
  88. public function index(): JsonResponse
  89. {
  90. try {
  91. $search = request()->validate([
  92. 'page' => ['nullable', 'integer', 'min:1'],
  93. 'limit' => ['nullable', 'integer', 'min:1'],
  94. 'member_id' => ['nullable', 'string', 'min:1'],
  95. 'like_first_name' => ['nullable', 'string', 'min:1'],
  96. 'username' => ['nullable', 'string', 'min:1'],
  97. 'register_ip' => ['nullable', 'string', 'min:1'],
  98. 'order' => ["nullable", 'string', "in:asc,desc"],
  99. 'by' => ['nullable', 'string', "in:available_balance,created_at,last_active_time"],
  100. 'user_code' => ['nullable'],
  101. 'agent_user_code' => ['nullable'],
  102. 'level' => ['nullable'],
  103. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  104. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  105. 'recharge_channel_group_id' => ['nullable'],
  106. ]);
  107. $order = request()->input('order', 'desc');
  108. $by = request()->input('by', 'available_balance');
  109. $result = UserService::paginate($search,$order,$by);
  110. } catch (ValidationException $e) {
  111. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first().'ssss');
  112. } catch (Exception $e) {
  113. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  114. }
  115. return $this->success($result);
  116. }
  117. public function merge(): JsonResponse
  118. {
  119. DB::beginTransaction();
  120. try {
  121. $params = request()->validate([
  122. 'member_id' => ['required', 'string', 'min:1'],
  123. 'secret_key' => ['required', 'string', 'min:1'],
  124. ]);
  125. $res = SecretService::migration($params['member_id'], $params['secret_key']);
  126. if (!$res) {
  127. throw new Exception(lang("迁移失败"), HttpStatus::CUSTOM_ERROR);
  128. }
  129. $oldUser = UserModel::where('secret_key', $params['secret_key'])->first();
  130. $newUser = UserModel::where('member_id', $params['member_id'])->first();
  131. App::setLocale($oldUser->language);
  132. $text = lang('账户转移通知') . ":\n";
  133. $text .= lang('管理员已将您的账户转移至新用户') . "\n\n";
  134. $text .= lang('新用户信息') . "\n";
  135. $text .= lang('用户ID') . ":{$newUser->getMemberId()}\n";
  136. if ($newUser->getUsername()) {
  137. $text .= lang("用户名") . ":@{$newUser->getUsername()}\n";
  138. }
  139. $text .= lang('昵称') . ":{$newUser->getFirstName()}\n";
  140. TopUpService::notifyTransferSuccess($oldUser->getMemberId(), $text);
  141. App::setLocale($newUser->language);
  142. $text = lang("账户转移通知") . ":\n";
  143. $text .= lang("管理员已将指定账户转移至您的账户") . "\n\n";
  144. $text .= lang('原账户信息') . "\n\n";
  145. $text .= lang('用户ID') . ":{$oldUser->getMemberId()}\n";
  146. if ($oldUser->getUsername()) {
  147. $text .= lang('用户名') . ":@{$oldUser->getUsername()}\n";
  148. }
  149. $text .= lang('昵称') . ":{$oldUser->getFirstName()}\n";
  150. TopUpService::notifyTransferSuccess($newUser->getMemberId(), $text);
  151. DB::commit();
  152. } catch (ValidationException $e) {
  153. DB::rollBack();
  154. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  155. } catch (Exception $e) {
  156. DB::rollBack();
  157. if ($e->getCode() == HttpStatus::CUSTOM_ERROR) {
  158. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  159. }
  160. return $this->error(intval($e->getCode()));
  161. }
  162. return $this->success(msg: '已完成迁移');
  163. }
  164. public function address()
  165. {
  166. try {
  167. request()->validate([
  168. 'member_id' => ['required', 'integer', 'min:1'],
  169. ]);
  170. $search = request()->all();
  171. $result = AddressService::findAll($search);
  172. } catch (ValidationException $e) {
  173. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  174. } catch (Exception $e) {
  175. return $this->error(intval($e->getCode()));
  176. }
  177. return $this->success($result);
  178. }
  179. /**
  180. * 用户登录日志
  181. */
  182. public function loginLog()
  183. {
  184. try {
  185. $params = request()->validate([
  186. 'page' => ['nullable', 'integer', 'min:1'],
  187. 'limit' => ['nullable', 'integer', 'min:1'],
  188. 'user_id' => ['nullable'],
  189. 'member_id' => ['nullable'],
  190. 'first_name' => ['nullable'],
  191. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  192. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  193. ]);
  194. $page = request()->input('page', 1);
  195. $limit = request()->input('limit', 15);
  196. $query = UserLogin::join('users', 'user_login.user_id', '=', 'users.user_id');
  197. if (!empty($params['user_id'])) {
  198. $query = $query->where('user_login.user_id', $params['user_id']);
  199. }
  200. if (!empty($params['member_id'])) {
  201. $query = $query->where('user_login.user_id', $params['member_id']);
  202. }
  203. if (!empty($params['first_name'])) {
  204. $query = $query->where('users.first_name', 'like', "%{$params['first_name']}%");
  205. }
  206. if (!empty($params['start_time'])) {
  207. $startTime = $params['start_time'] . " 00:00:00";
  208. $query = $query->where('user_login.created_at', '>=', $startTime);
  209. }
  210. if (!empty($params['end_time'])) {
  211. $endTime = $params['end_time'] . " 23:59:59";
  212. $query = $query->where('user_login.updated_at', '<=', $endTime);
  213. }
  214. $count = $query->count();
  215. $list = $query
  216. ->forPage($page, $limit)
  217. ->orderByDesc('user_login.created_at')
  218. ->get();
  219. } catch (Exception $e) {
  220. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  221. }
  222. return $this->success(['total' => $count, 'data' => $list]);
  223. }
  224. function setRechargeChannelGroup()
  225. {
  226. try {
  227. $params = request()->validate([
  228. 'member_id' => ['required', 'array'],
  229. 'recharge_channel_group_id' => ['required', 'integer', 'min:1'],
  230. ]);
  231. UserModel::whereIn('member_id', $params['member_id'])->update(['recharge_channel_group_id' => $params['recharge_channel_group_id']]);
  232. } catch (ValidationException $e) {
  233. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  234. } catch (Exception $e) {
  235. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  236. }
  237. return $this->success();
  238. }
  239. }