Created
October 28, 2018 13:26
-
-
Save muhtarudinsiregar/6493d59f86413ce54dc8b3496504d771 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App\Http\Controllers; | |
use Illuminate\Http\Request; | |
use Auth; | |
class AuthController extends Controller | |
{ | |
/** | |
* Create a new AuthController instance. | |
* | |
* @return void | |
*/ | |
public function __construct() | |
{ | |
$this->middleware('auth:api', ['except' => ['login']]); | |
} | |
/** | |
* Get a JWT token via given credentials. | |
* | |
* @param \Illuminate\Http\Request $request | |
* | |
* @return \Illuminate\Http\JsonResponse | |
*/ | |
public function login(Request $request) | |
{ | |
$credentials = $request->only('email', 'password'); | |
if ($token = $this->guard()->attempt($credentials)) { | |
return $this->respondWithToken($token); | |
} | |
return response()->json(['error' => 'Invalid Login Details'], 401); | |
} | |
/** | |
* Get the authenticated User. | |
* | |
* @return \Illuminate\Http\JsonResponse | |
*/ | |
public function me() | |
{ | |
return response()->json($this->guard()->user(), 200); | |
} | |
/** | |
* Log the user out (Invalidate the token). | |
* | |
* @return \Illuminate\Http\JsonResponse | |
*/ | |
public function logout() | |
{ | |
$this->guard()->logout(); | |
return response()->json(['message' => 'Successfully logged out']); | |
} | |
/** | |
* Refresh a token. | |
* | |
* @return \Illuminate\Http\JsonResponse | |
*/ | |
public function refresh() | |
{ | |
return $this->respondWithToken($this->guard()->refresh()); | |
} | |
/** | |
* Get the token array structure. | |
* | |
* @param string $token | |
* | |
* @return \Illuminate\Http\JsonResponse | |
*/ | |
protected function respondWithToken($token) | |
{ | |
return response()->json([ | |
'access_token' => $token, | |
'token_type' => 'bearer', | |
'expires_in' => $this->guard()->factory()->getTTL() * 60, | |
]); | |
} | |
/** | |
* Get the guard to be used during authentication. | |
* | |
* @return \Illuminate\Contracts\Auth\Guard | |
*/ | |
public function guard() | |
{ | |
return Auth::guard('api'); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment