User.php 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  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. class User extends Controller
  18. {
  19. function banned()
  20. {
  21. try {
  22. $params = request()->validate([
  23. 'member_id' => ['required', 'string', 'min:1'],
  24. 'is_banned' => ['required', 'integer', 'in:0,1'],
  25. ]);
  26. UserModel::where('member_id', $params['member_id'])->update(['is_banned' => $params['is_banned']]);
  27. if ($params['is_banned'] == 1) {
  28. //如果用户被禁用,删除所有会话
  29. UserSession::where('user_id', $params['member_id'])->delete();
  30. return $this->success();
  31. }
  32. } catch (ValidationException $e) {
  33. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  34. } catch (Exception $e) {
  35. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  36. }
  37. return $this->success();
  38. }
  39. function setNote()
  40. {
  41. try {
  42. $params = request()->validate([
  43. 'member_id' => ['required', 'string', 'min:1'],
  44. 'admin_note' => ['required', 'string', 'min:1', 'max:120'],
  45. ]);
  46. $user = UserModel::where('member_id', $params['member_id'])->first();
  47. if (!$user) throw new Exception("用户不存在", HttpStatus::CUSTOM_ERROR);
  48. $user->admin_note = $params['admin_note'];
  49. $user->save();
  50. } catch (ValidationException $e) {
  51. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  52. } catch (Exception $e) {
  53. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  54. }
  55. return $this->success();
  56. }
  57. public function index(): JsonResponse
  58. {
  59. try {
  60. $search = request()->validate([
  61. 'page' => ['nullable', 'integer', 'min:1'],
  62. 'limit' => ['nullable', 'integer', 'min:1'],
  63. 'member_id' => ['nullable', 'string', 'min:1'],
  64. 'like_first_name' => ['nullable', 'string', 'min:1'],
  65. 'username' => ['nullable', 'string', 'min:1'],
  66. 'register_ip' => ['nullable', 'string', 'min:1'],
  67. 'order' => ["nullable", 'string', "in:asc,desc"],
  68. 'by' => ['nullable', 'string', "in:available_balance,created_at,last_active_time"],
  69. 'user_code' => ['nullable'],
  70. 'agent_user_code' => ['nullable'],
  71. 'level' => ['nullable'],
  72. ]);
  73. $order = request()->input('order', 'desc');
  74. $by = request()->input('by', 'available_balance');
  75. $result = UserService::paginate($search,$order,$by);
  76. } catch (ValidationException $e) {
  77. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first().'ssss');
  78. } catch (Exception $e) {
  79. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  80. }
  81. return $this->success($result);
  82. }
  83. public function merge(): JsonResponse
  84. {
  85. DB::beginTransaction();
  86. try {
  87. $params = request()->validate([
  88. 'member_id' => ['required', 'string', 'min:1'],
  89. 'secret_key' => ['required', 'string', 'min:1'],
  90. ]);
  91. $res = SecretService::migration($params['member_id'], $params['secret_key']);
  92. if (!$res) {
  93. throw new Exception(lang("迁移失败"), HttpStatus::CUSTOM_ERROR);
  94. }
  95. $oldUser = UserModel::where('secret_key', $params['secret_key'])->first();
  96. $newUser = UserModel::where('member_id', $params['member_id'])->first();
  97. App::setLocale($oldUser->language);
  98. $text = lang('账户转移通知') . ":\n";
  99. $text .= lang('管理员已将您的账户转移至新用户') . "\n\n";
  100. $text .= lang('新用户信息') . "\n";
  101. $text .= lang('用户ID') . ":{$newUser->getMemberId()}\n";
  102. if ($newUser->getUsername()) {
  103. $text .= lang("用户名") . ":@{$newUser->getUsername()}\n";
  104. }
  105. $text .= lang('昵称') . ":{$newUser->getFirstName()}\n";
  106. TopUpService::notifyTransferSuccess($oldUser->getMemberId(), $text);
  107. App::setLocale($newUser->language);
  108. $text = lang("账户转移通知") . ":\n";
  109. $text .= lang("管理员已将指定账户转移至您的账户") . "\n\n";
  110. $text .= lang('原账户信息') . "\n\n";
  111. $text .= lang('用户ID') . ":{$oldUser->getMemberId()}\n";
  112. if ($oldUser->getUsername()) {
  113. $text .= lang('用户名') . ":@{$oldUser->getUsername()}\n";
  114. }
  115. $text .= lang('昵称') . ":{$oldUser->getFirstName()}\n";
  116. TopUpService::notifyTransferSuccess($newUser->getMemberId(), $text);
  117. DB::commit();
  118. } catch (ValidationException $e) {
  119. DB::rollBack();
  120. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  121. } catch (Exception $e) {
  122. DB::rollBack();
  123. if ($e->getCode() == HttpStatus::CUSTOM_ERROR) {
  124. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  125. }
  126. return $this->error(intval($e->getCode()));
  127. }
  128. return $this->success(msg: '已完成迁移');
  129. }
  130. public function address()
  131. {
  132. try {
  133. request()->validate([
  134. 'member_id' => ['required', 'integer', 'min:1'],
  135. ]);
  136. $search = request()->all();
  137. $result = AddressService::findAll($search);
  138. } catch (ValidationException $e) {
  139. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  140. } catch (Exception $e) {
  141. return $this->error(intval($e->getCode()));
  142. }
  143. return $this->success($result);
  144. }
  145. /**
  146. * 用户登录日志
  147. */
  148. public function loginLog()
  149. {
  150. try {
  151. $params = request()->validate([
  152. 'page' => ['nullable', 'integer', 'min:1'],
  153. 'limit' => ['nullable', 'integer', 'min:1'],
  154. 'user_id' => ['nullable'],
  155. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  156. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  157. ]);
  158. $page = request()->input('page', 1);
  159. $limit = request()->input('limit', 15);
  160. $query = new UserLogin();
  161. if (!empty($params['user_id'])) {
  162. $query = $query->where('user_id', $params['user_id']);
  163. }
  164. if (!empty($params['start_time'])) {
  165. $startTime = $params['start_time'] . " 00:00:00";
  166. $query = $query->where('created_at', '>=', $startTime);
  167. }
  168. if (!empty($params['end_time'])) {
  169. $endTime = $params['end_time'] . " 23:59:59";
  170. $query = $query->where('updated_at', '<=', $endTime);
  171. }
  172. $count = $query->count();
  173. $list = $query
  174. ->forPage($page, $limit)
  175. ->orderByDesc('created_at')
  176. ->get();
  177. } catch (Exception $e) {
  178. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  179. }
  180. return $this->success(['total' => $count, 'data' => $list]);
  181. }
  182. }