User.php 10 KB

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