User.php 10 KB

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