User.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Constants\HttpStatus;
  4. use App\Http\Controllers\Controller;
  5. use App\Services\RoomService;
  6. use App\Services\SecretService;
  7. use App\Services\TopUpService;
  8. use Illuminate\Support\Facades\App;
  9. use Illuminate\Support\Facades\Auth;
  10. use Illuminate\Support\Facades\DB;
  11. use Illuminate\Support\Facades\Validator;
  12. use App\Services\UserService;
  13. use Exception;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Validation\ValidationException;
  16. use App\Services\AddressService;
  17. use Illuminate\Http\JsonResponse;
  18. use App\Models\User as UserModel;
  19. class User extends Controller
  20. {
  21. function banned()
  22. {
  23. try {
  24. $params = request()->validate([
  25. 'member_id' => ['required', 'string', 'min:1'],
  26. 'is_banned' => ['required', 'integer', 'in:0,1'],
  27. ]);
  28. UserModel::where('member_id', $params['member_id'])->update(['is_banned' => $params['is_banned']]);
  29. } catch (ValidationException $e) {
  30. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  31. } catch (Exception $e) {
  32. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  33. }
  34. return $this->success();
  35. }
  36. function setNote()
  37. {
  38. try {
  39. $params = request()->validate([
  40. 'member_id' => ['required', 'string', 'min:1'],
  41. 'admin_note' => ['required', 'string', 'min:1', 'max:120'],
  42. ]);
  43. $user = UserModel::where('member_id', $params['member_id'])->first();
  44. if (!$user) throw new Exception("用户不存在", HttpStatus::CUSTOM_ERROR);
  45. $user->admin_note = $params['admin_note'];
  46. $user->save();
  47. } catch (ValidationException $e) {
  48. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  49. } catch (Exception $e) {
  50. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  51. }
  52. return $this->success();
  53. }
  54. /**
  55. * @api {get} /admin/user 会员列表
  56. * @apiGroup 会员管理
  57. *
  58. * @apiUse result
  59. * @apiUse header
  60. * @apiVersion 1.0.0
  61. *
  62. * @apiParam {int} [page=1]
  63. * @apiParam {int} [limit=10]
  64. * @apiParam {string} [first_name] 用户昵称
  65. * @apiParam {string} [member_id] 房主 tg会员ID
  66. * @apiParam {string} [game_id] 游戏ID
  67. *
  68. * @apiSuccess (data) {Object} data
  69. * @apiSuccess (data) {int} data.total 数量
  70. * @apiSuccess (data) {Object[]} data.data 列表
  71. * @apiSuccess (data) {int} data.data.id
  72. * @apiSuccess (data) {int} data.data.member_id tg会员id
  73. * @apiSuccess (data) {string} data.data.first_name 昵称
  74. * @apiSuccess (data) {string} data.data.usdt 用户usdt钱包地址
  75. * @apiSuccess (data) {string} data.data.game_id 游戏ID
  76. * @apiSuccess (data) {string} data.data.updated_at
  77. * @apiSuccess (data) {string} data.data.created_at
  78. * @apiSuccess (data) {string} data.data.secret_key 找回账号的秘钥
  79. */
  80. public function index(): JsonResponse
  81. {
  82. try {
  83. $search = request()->validate([
  84. 'page' => ['nullable', 'integer', 'min:1'],
  85. 'limit' => ['nullable', 'integer', 'min:1'],
  86. 'member_id' => ['nullable', 'string', 'min:1'],
  87. 'first_name' => ['nullable', 'string', 'min:1'],
  88. 'username' => ['nullable', 'string', 'min:1'],
  89. ]);
  90. $result = UserService::paginate($search);
  91. } catch (ValidationException $e) {
  92. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  93. } catch (Exception $e) {
  94. return $this->error(intval($e->getCode()));
  95. }
  96. return $this->success($result);
  97. }
  98. /**
  99. * @api {post} /admin/user/merge 账户合并
  100. * @apiGroup 会员管理
  101. * @apiDescription 合并后,余额,银行卡,USDT地址 将合并到新用户,请谨慎操作
  102. *
  103. * @apiUse result
  104. * @apiUse header
  105. * @apiVersion 1.0.0
  106. *
  107. * @apiParam {string} member_id 接收者的member_id
  108. * @apiParam {string} secret_key 被合并的用户的秘钥
  109. */
  110. public function merge(): JsonResponse
  111. {
  112. DB::beginTransaction();
  113. try {
  114. $params = request()->validate([
  115. 'member_id' => ['required', 'string', 'min:1'],
  116. 'secret_key' => ['required', 'string', 'min:1'],
  117. ]);
  118. $res = SecretService::migration($params['member_id'], $params['secret_key']);
  119. if (!$res) {
  120. throw new Exception(lang("迁移失败"), HttpStatus::CUSTOM_ERROR);
  121. }
  122. $oldUser = UserModel::where('secret_key', $params['secret_key'])->first();
  123. $newUser = UserModel::where('member_id', $params['member_id'])->first();
  124. App::setLocale($oldUser->language);
  125. $text = lang('账户转移通知') . ":\n";
  126. $text .= lang('管理员已将您的账户转移至新用户') . "\n\n";
  127. $text .= lang('新用户信息') . "\n";
  128. $text .= lang('用户ID') . ":{$newUser->getMemberId()}\n";
  129. if ($newUser->getUsername()) {
  130. $text .= lang("用户名") . ":@{$newUser->getUsername()}\n";
  131. }
  132. $text .= lang('昵称') . ":{$newUser->getFirstName()}\n";
  133. TopUpService::notifyTransferSuccess($oldUser->getMemberId(), $text);
  134. App::setLocale($newUser->language);
  135. $text = lang("账户转移通知") . ":\n";
  136. $text .= lang("管理员已将指定账户转移至您的账户") . "\n\n";
  137. $text .= lang('原账户信息') . "\n\n";
  138. $text .= lang('用户ID') . ":{$oldUser->getMemberId()}\n";
  139. if ($oldUser->getUsername()) {
  140. $text .= lang('用户名') . ":@{$oldUser->getUsername()}\n";
  141. }
  142. $text .= lang('昵称') . ":{$oldUser->getFirstName()}\n";
  143. TopUpService::notifyTransferSuccess($newUser->getMemberId(), $text);
  144. DB::commit();
  145. } catch (ValidationException $e) {
  146. DB::rollBack();
  147. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  148. } catch (Exception $e) {
  149. DB::rollBack();
  150. if ($e->getCode() == HttpStatus::CUSTOM_ERROR) {
  151. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  152. }
  153. return $this->error(intval($e->getCode()));
  154. }
  155. return $this->success(msg: '已完成迁移');
  156. }
  157. public function address()
  158. {
  159. try {
  160. request()->validate([
  161. 'member_id' => ['required', 'integer', 'min:1'],
  162. ]);
  163. $search = request()->all();
  164. $result = AddressService::findAll($search);
  165. } catch (ValidationException $e) {
  166. return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());
  167. } catch (Exception $e) {
  168. return $this->error(intval($e->getCode()));
  169. }
  170. return $this->success($result);
  171. }
  172. }