User.php 11 KB

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