V1Controller.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. namespace App\Http\Controllers\Api\Client;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\Goods;
  5. use App\Models\User;
  6. use Illuminate\Http\Request;
  7. use Validator;
  8. class V1Controller extends Controller
  9. {
  10. public function __construct()
  11. {
  12. $this->middleware('auth:api', ['except' => ['login', 'register', 'shop']]);
  13. auth()->shouldUse('api');
  14. }
  15. public function login(Request $request)
  16. {
  17. $validator = Validator::make($request->all(), [
  18. 'email' => 'required|email',
  19. 'password' => 'required|string|min:6',
  20. ]);
  21. if ($validator->fails()) {
  22. return response()->json(['ret' => 0, 'msg' => $validator->errors()->all()], 422);
  23. }
  24. if ($token = auth()->attempt($validator->validated())) {
  25. return $this->createNewToken($token);
  26. }
  27. return response()->json(['ret' => 0, 'msg' => '登录信息错误'], 401);
  28. }
  29. protected function createNewToken($token)
  30. {
  31. return response()->json([
  32. 'ret' => 1,
  33. 'access_token' => $token,
  34. 'token_type' => 'bearer',
  35. 'expires_in' => auth()->factory()->getTTL() * 60,
  36. 'user' => auth()->user()->profile(),
  37. ]);
  38. }
  39. public function register(Request $request)
  40. {
  41. $validator = Validator::make($request->all(), [
  42. 'name' => 'required|string|between:2,100',
  43. 'email' => 'required|string|email|max:100|unique:users',
  44. 'password' => 'required|string|confirmed|min:6',
  45. ]);
  46. if ($validator->fails()) {
  47. return response()->json($validator->errors()->all(), 400);
  48. }
  49. $user = User::create(array_merge(
  50. $validator->validated(),
  51. ['password' => $request->password]
  52. ));
  53. return response()->json(['ret' => 1, 'user' => $user], 201);
  54. }
  55. public function logout()
  56. {
  57. auth()->logout();
  58. return response()->json(['ret' => 1]);
  59. }
  60. public function refresh()
  61. {
  62. return $this->createNewToken(auth()->refresh());
  63. }
  64. public function userProfile()
  65. {
  66. return response()->json(auth()->user()->profile());
  67. }
  68. public function nodeList(int $id = null)
  69. {
  70. $user = auth()->user();
  71. $nodes = $user->nodes()->get();
  72. if (isset($id)) {
  73. $node = $nodes->find($id);
  74. if (empty($node)) {
  75. return response()->json([], 204);
  76. }
  77. return response()->json($node->config($user));
  78. }
  79. $servers = [];
  80. foreach ($nodes as $node) {
  81. $servers[] = $node->config($user);
  82. }
  83. return response()->json($servers);
  84. }
  85. public function shop()
  86. {
  87. $shop = Goods::whereStatus(1)->where('type', '<=', '2')->orderByDesc('type')->orderByDesc('sort')->get();
  88. return response()->json($shop);
  89. }
  90. }