Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- <?php
- namespace App\Http\Controllers\Api;
- use Illuminate\Http\Request;
- use App\Http\Controllers\Controller;
- use App\Models\User;
- use Carbon\Carbon;
- use Auth;
- class AuthController extends Controller
- {
- /**
- * Display a listing of the resource.
- *
- * @return \Illuminate\Http\Response
- */
- public function register(Request $request)
- {
- $request->validate([
- 'name' => 'required|string',
- 'email' => 'required|string|email|unique:users',
- 'password' => 'required|string|confirmed'
- ]);
- $user = new User([
- 'name' => $request->name,
- 'email' => $request->email,
- 'password' => bcrypt($request->password)
- ]);
- $user->save();
- return response()->json([
- 'message' => 'Successfully created user!'
- ], 201);
- }
- public function login(Request $request)
- {
- $request->validate([
- 'email' => 'required|string|email',
- 'password' => 'required|string',
- 'remember_me' => 'boolean'
- ]);
- $credentials = request(['email', 'password']);
- if(!Auth::attempt($credentials))
- return response()->json([
- 'message' => 'Unauthorized'
- ], 401);
- $user = $request->user();
- $tokenResult = $user->createToken('Personal Access Token');
- $token = $tokenResult->token;
- if ($request->remember_me)
- $token->expires_at = Carbon::now()->addWeeks(1);
- $token->save();
- return response()->json([
- 'access_token' => $tokenResult->accessToken,
- 'token_type' => 'Bearer',
- 'user' => $user,
- 'expires_at' => Carbon::parse(
- $tokenResult->token->expires_at
- )->toDateTimeString()
- ]);
- }
- public function logout(Request $request)
- {
- $request->user()->token()->revoke();
- return response()->json([
- 'message' => 'Successfully logged out'
- ]);
- }
- public function user(Request $request)
- {
- return response()->json($request->user());
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement