User.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  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. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  73. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  74. 'recharge_channel_group_id' => ['nullable'],
  75. ]);
  76. $order = request()->input('order', 'desc');
  77. $by = request()->input('by', 'available_balance');
  78. $result = UserService::paginate($search,$order,$by);
  79. } catch (ValidationException $e) {
  80. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first().'ssss');
  81. } catch (Exception $e) {
  82. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  83. }
  84. return $this->success($result);
  85. }
  86. public function merge(): JsonResponse
  87. {
  88. DB::beginTransaction();
  89. try {
  90. $params = request()->validate([
  91. 'member_id' => ['required', 'string', 'min:1'],
  92. 'secret_key' => ['required', 'string', 'min:1'],
  93. ]);
  94. $res = SecretService::migration($params['member_id'], $params['secret_key']);
  95. if (!$res) {
  96. throw new Exception(lang("迁移失败"), HttpStatus::CUSTOM_ERROR);
  97. }
  98. $oldUser = UserModel::where('secret_key', $params['secret_key'])->first();
  99. $newUser = UserModel::where('member_id', $params['member_id'])->first();
  100. App::setLocale($oldUser->language);
  101. $text = lang('账户转移通知') . ":\n";
  102. $text .= lang('管理员已将您的账户转移至新用户') . "\n\n";
  103. $text .= lang('新用户信息') . "\n";
  104. $text .= lang('用户ID') . ":{$newUser->getMemberId()}\n";
  105. if ($newUser->getUsername()) {
  106. $text .= lang("用户名") . ":@{$newUser->getUsername()}\n";
  107. }
  108. $text .= lang('昵称') . ":{$newUser->getFirstName()}\n";
  109. TopUpService::notifyTransferSuccess($oldUser->getMemberId(), $text);
  110. App::setLocale($newUser->language);
  111. $text = lang("账户转移通知") . ":\n";
  112. $text .= lang("管理员已将指定账户转移至您的账户") . "\n\n";
  113. $text .= lang('原账户信息') . "\n\n";
  114. $text .= lang('用户ID') . ":{$oldUser->getMemberId()}\n";
  115. if ($oldUser->getUsername()) {
  116. $text .= lang('用户名') . ":@{$oldUser->getUsername()}\n";
  117. }
  118. $text .= lang('昵称') . ":{$oldUser->getFirstName()}\n";
  119. TopUpService::notifyTransferSuccess($newUser->getMemberId(), $text);
  120. DB::commit();
  121. } catch (ValidationException $e) {
  122. DB::rollBack();
  123. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  124. } catch (Exception $e) {
  125. DB::rollBack();
  126. if ($e->getCode() == HttpStatus::CUSTOM_ERROR) {
  127. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  128. }
  129. return $this->error(intval($e->getCode()));
  130. }
  131. return $this->success(msg: '已完成迁移');
  132. }
  133. public function address()
  134. {
  135. try {
  136. request()->validate([
  137. 'member_id' => ['required', 'integer', 'min:1'],
  138. ]);
  139. $search = request()->all();
  140. $result = AddressService::findAll($search);
  141. } catch (ValidationException $e) {
  142. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  143. } catch (Exception $e) {
  144. return $this->error(intval($e->getCode()));
  145. }
  146. return $this->success($result);
  147. }
  148. /**
  149. * 用户登录日志
  150. */
  151. public function loginLog()
  152. {
  153. try {
  154. $params = request()->validate([
  155. 'page' => ['nullable', 'integer', 'min:1'],
  156. 'limit' => ['nullable', 'integer', 'min:1'],
  157. 'user_id' => ['nullable'],
  158. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  159. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  160. ]);
  161. $page = request()->input('page', 1);
  162. $limit = request()->input('limit', 15);
  163. $query = new UserLogin();
  164. if (!empty($params['user_id'])) {
  165. $query = $query->where('user_id', $params['user_id']);
  166. }
  167. if (!empty($params['start_time'])) {
  168. $startTime = $params['start_time'] . " 00:00:00";
  169. $query = $query->where('created_at', '>=', $startTime);
  170. }
  171. if (!empty($params['end_time'])) {
  172. $endTime = $params['end_time'] . " 23:59:59";
  173. $query = $query->where('updated_at', '<=', $endTime);
  174. }
  175. $count = $query->count();
  176. $list = $query
  177. ->forPage($page, $limit)
  178. ->orderByDesc('created_at')
  179. ->get();
  180. } catch (Exception $e) {
  181. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  182. }
  183. return $this->success(['total' => $count, 'data' => $list]);
  184. }
  185. function setRechargeChannelGroup()
  186. {
  187. try {
  188. $params = request()->validate([
  189. 'member_id' => ['required', 'array'],
  190. 'recharge_channel_group_id' => ['required', 'integer', 'min:1'],
  191. ]);
  192. UserModel::whereIn('member_id', $params['member_id'])->update(['recharge_channel_group_id' => $params['recharge_channel_group_id']]);
  193. } catch (ValidationException $e) {
  194. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  195. } catch (Exception $e) {
  196. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  197. }
  198. return $this->success();
  199. }
  200. }