UserController.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  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 export(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. }
  115. public function generate(UserGenerate $request)
  116. {
  117. if ($request->input('email_prefix')) {
  118. if ($request->input('plan_id')) {
  119. $plan = Plan::find($request->input('plan_id'));
  120. if (!$plan) {
  121. abort(500, '订阅计划不存在');
  122. }
  123. }
  124. $user = [
  125. 'email' => $request->input('email_prefix') . '@' . $request->input('email_suffix'),
  126. 'plan_id' => isset($plan->id) ? $plan->id : NULL,
  127. 'group_id' => isset($plan->group_id) ? $plan->group_id : NULL,
  128. 'transfer_enable' => isset($plan->transfer_enable) ? $plan->transfer_enable * 1073741824 : 0,
  129. 'expired_at' => $request->input('expired_at') ?? NULL,
  130. 'uuid' => Helper::guid(true),
  131. 'token' => Helper::guid()
  132. ];
  133. $user['password'] = password_hash($request->input('password') ?? $user['email'], PASSWORD_DEFAULT);
  134. if (!User::create($user)) {
  135. abort(500, '生成失败');
  136. }
  137. return response([
  138. 'data' => true
  139. ]);
  140. }
  141. if ($request->input('count')) {
  142. $this->multiGenerate($request);
  143. }
  144. }
  145. private function multiGenerate(Request $request)
  146. {
  147. if ($request->input('plan_id')) {
  148. $plan = Plan::find($request->input('plan_id'));
  149. if (!$plan) {
  150. abort(500, '订阅计划不存在');
  151. }
  152. }
  153. $users = [];
  154. for ($i = 0;$i < $request->input('count');$i++) {
  155. $user = [
  156. 'email' => Helper::randomChar(6) . '@' . $request->input('email_suffix'),
  157. 'plan_id' => isset($plan->id) ? $plan->id : NULL,
  158. 'group_id' => isset($plan->group_id) ? $plan->group_id : NULL,
  159. 'transfer_enable' => isset($plan->transfer_enable) ? $plan->transfer_enable * 1073741824 : 0,
  160. 'expired_at' => $request->input('expired_at') ?? NULL,
  161. 'uuid' => Helper::guid(true),
  162. 'token' => Helper::guid(),
  163. 'created_at' => time(),
  164. 'updated_at' => time()
  165. ];
  166. $user['password'] = password_hash($request->input('password') ?? $user['email'], PASSWORD_DEFAULT);
  167. array_push($users, $user);
  168. }
  169. DB::beginTransaction();
  170. if (!User::insert($users)) {
  171. DB::rollBack();
  172. abort(500, '生成失败');
  173. }
  174. DB::commit();
  175. $data = "账号,密码,过期时间,UUID,创建时间\r\n";
  176. foreach($users as $user) {
  177. $expireDate = $user['expired_at'] === NULL ? '长期有效' : $user['expired_at'];
  178. $createDate = date('Y-m-d H:i:s', $user['created_at']);
  179. $password = $request->input('password') ?? $user['email'];
  180. $data .= "{$user['email']},{$password},{$expireDate},{$user['uuid']},{$createDate}\r\n";
  181. }
  182. echo $data;
  183. }
  184. }