UserController.php 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Requests\Admin\UserFetch;
  4. use App\Http\Requests\Admin\UserGenerate;
  5. use App\Http\Requests\Admin\UserUpdate;
  6. use App\Utils\Helper;
  7. use Illuminate\Http\Request;
  8. use App\Http\Controllers\Controller;
  9. use App\Models\Order;
  10. use App\Models\User;
  11. use App\Models\Plan;
  12. use Illuminate\Support\Facades\DB;
  13. class UserController extends Controller
  14. {
  15. private function filter(Request $request, $builder)
  16. {
  17. if ($request->input('filter')) {
  18. $request->validate([
  19. 'filter' => 'array',
  20. 'filter.*.key' => 'required|in:email,transfer_enable,d,expired_at,uuid,token',
  21. 'filter.*.condition' => 'required|in:>,<,=,>=,<=',
  22. 'filter.*.value' => 'required'
  23. ]);
  24. foreach ($request->input('filter') as $filter) {
  25. if ($filter['key'] === 'email' && $filter['condition'] === '=') {
  26. $builder->where($filter['key'], 'like', '%' . $filter['value'] . '%');
  27. continue;
  28. }
  29. if ($filter['key'] === 'd' || $filter['key'] === 'transfer_enable') {
  30. $filter['value'] = $filter['value'] * 1073741824;
  31. }
  32. $builder->where($filter['key'], $filter['condition'], $filter['value']);
  33. }
  34. }
  35. }
  36. public function fetch(UserFetch $request)
  37. {
  38. $current = $request->input('current') ? $request->input('current') : 1;
  39. $pageSize = $request->input('pageSize') >= 10 ? $request->input('pageSize') : 10;
  40. $sortType = in_array($request->input('sort_type'), ['ASC', 'DESC']) ? $request->input('sort_type') : 'DESC';
  41. $sort = $request->input('sort') ? $request->input('sort') : 'created_at';
  42. $userModel = User::orderBy($sort, $sortType);
  43. $this->filter($request, $userModel);
  44. $total = $userModel->count();
  45. $res = $userModel->forPage($current, $pageSize)
  46. ->get();
  47. $plan = Plan::get();
  48. for ($i = 0; $i < count($res); $i++) {
  49. for ($k = 0; $k < count($plan); $k++) {
  50. if ($plan[$k]['id'] == $res[$i]['plan_id']) {
  51. $res[$i]['plan_name'] = $plan[$k]['name'];
  52. }
  53. }
  54. }
  55. return response([
  56. 'data' => $res,
  57. 'total' => $total
  58. ]);
  59. }
  60. public function getUserInfoById(Request $request)
  61. {
  62. if (empty($request->input('id'))) {
  63. abort(500, '参数错误');
  64. }
  65. return response([
  66. 'data' => User::find($request->input('id'))
  67. ]);
  68. }
  69. public function update(UserUpdate $request)
  70. {
  71. $params = $request->validated();
  72. $user = User::find($request->input('id'));
  73. if (!$user) {
  74. abort(500, '用户不存在');
  75. }
  76. if (User::where('email', $params['email'])->first() && $user->email !== $params['email']) {
  77. abort(500, '邮箱已被使用');
  78. }
  79. if (isset($params['password'])) {
  80. $params['password'] = password_hash($params['password'], PASSWORD_DEFAULT);
  81. $params['password_algo'] = NULL;
  82. } else {
  83. unset($params['password']);
  84. }
  85. if (isset($params['plan_id'])) {
  86. $plan = Plan::find($params['plan_id']);
  87. if (!$plan) {
  88. abort(500, '订阅计划不存在');
  89. }
  90. $params['group_id'] = $plan->group_id;
  91. }
  92. try {
  93. $user->update($params);
  94. } catch (\Exception $e) {
  95. abort(500, '保存失败');
  96. }
  97. return response([
  98. 'data' => true
  99. ]);
  100. }
  101. public function dumpCSV(Request $request)
  102. {
  103. $userModel = new User();
  104. $this->filter($request, $userModel);
  105. $res = $userModel->get();
  106. $plan = Plan::get();
  107. for ($i = 0; $i < count($res); $i++) {
  108. for ($k = 0; $k < count($plan); $k++) {
  109. if ($plan[$k]['id'] == $res[$i]['plan_id']) {
  110. $res[$i]['plan_name'] = $plan[$k]['name'];
  111. }
  112. }
  113. }
  114. $data = "邮箱,余额,推广佣金,总流量,剩余流量,套餐到期时间,订阅计划,订阅地址\r\n";
  115. $baseUrl = config('v2board.subscribe_url', config('v2board.app_url', env('APP_URL')));
  116. foreach($res as $user) {
  117. $expireDate = $user['expired_at'] === NULL ? '长期有效' : $user['expired_at'];
  118. $balance = $user['balance'] / 100;
  119. $commissionBalance = $user['commission_balance'] / 100;
  120. $transferEnable = $user['transfer_enable'] ? $user['transfer_enable'] / 1073741824 : 0;
  121. $notUseFlow = (($user['transfer_enable'] - ($user['u'] + $user['d'])) / 1073741824) ?? 0;
  122. $planName = $user['plan_name'] ?? '无订阅';
  123. $subscribeUrl = $baseUrl . '/api/v1/client/subscribe?token=' . $user['token'];
  124. $data .= "{$user['email']},{$balance},{$commissionBalance},{$transferEnable},{$notUseFlow},{$expireDate},{$planName},{$subscribeUrl}\r\n";
  125. }
  126. echo $data;
  127. }
  128. public function generate(UserGenerate $request)
  129. {
  130. if ($request->input('email_prefix')) {
  131. if ($request->input('plan_id')) {
  132. $plan = Plan::find($request->input('plan_id'));
  133. if (!$plan) {
  134. abort(500, '订阅计划不存在');
  135. }
  136. }
  137. $user = [
  138. 'email' => $request->input('email_prefix') . '@' . $request->input('email_suffix'),
  139. 'plan_id' => isset($plan->id) ? $plan->id : NULL,
  140. 'group_id' => isset($plan->group_id) ? $plan->group_id : NULL,
  141. 'transfer_enable' => isset($plan->transfer_enable) ? $plan->transfer_enable * 1073741824 : 0,
  142. 'expired_at' => $request->input('expired_at') ?? NULL,
  143. 'uuid' => Helper::guid(true),
  144. 'token' => Helper::guid()
  145. ];
  146. $user['password'] = password_hash($request->input('password') ?? $user['email'], PASSWORD_DEFAULT);
  147. if (!User::create($user)) {
  148. abort(500, '生成失败');
  149. }
  150. return response([
  151. 'data' => true
  152. ]);
  153. }
  154. if ($request->input('count')) {
  155. $this->multiGenerate($request);
  156. }
  157. }
  158. private function multiGenerate(Request $request)
  159. {
  160. if ($request->input('plan_id')) {
  161. $plan = Plan::find($request->input('plan_id'));
  162. if (!$plan) {
  163. abort(500, '订阅计划不存在');
  164. }
  165. }
  166. $users = [];
  167. for ($i = 0;$i < $request->input('count');$i++) {
  168. $user = [
  169. 'email' => Helper::randomChar(6) . '@' . $request->input('email_suffix'),
  170. 'plan_id' => isset($plan->id) ? $plan->id : NULL,
  171. 'group_id' => isset($plan->group_id) ? $plan->group_id : NULL,
  172. 'transfer_enable' => isset($plan->transfer_enable) ? $plan->transfer_enable * 1073741824 : 0,
  173. 'expired_at' => $request->input('expired_at') ?? NULL,
  174. 'uuid' => Helper::guid(true),
  175. 'token' => Helper::guid(),
  176. 'created_at' => time(),
  177. 'updated_at' => time()
  178. ];
  179. $user['password'] = password_hash($request->input('password') ?? $user['email'], PASSWORD_DEFAULT);
  180. array_push($users, $user);
  181. }
  182. DB::beginTransaction();
  183. if (!User::insert($users)) {
  184. DB::rollBack();
  185. abort(500, '生成失败');
  186. }
  187. DB::commit();
  188. $data = "账号,密码,过期时间,UUID,创建时间\r\n";
  189. foreach($users as $user) {
  190. $expireDate = $user['expired_at'] === NULL ? '长期有效' : $user['expired_at'];
  191. $createDate = date('Y-m-d H:i:s', $user['created_at']);
  192. $password = $request->input('password') ?? $user['email'];
  193. $data .= "{$user['email']},{$password},{$expireDate},{$user['uuid']},{$createDate}\r\n";
  194. }
  195. echo $data;
  196. }
  197. }