V1Controller.php 2.9 KB

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