95 lines
2.1 KiB
PHP
95 lines
2.1 KiB
PHP
<?php
|
|
/**
|
|
* AuthController.php
|
|
*
|
|
* @copyright 2023 beikeshop.com - All Rights Reserved
|
|
* @link https://beikeshop.com
|
|
* @author Edward Yang <yangjin@guangda.work>
|
|
* @created 2023-04-11 17:44:26
|
|
* @modified 2023-04-11 17:44:26
|
|
*/
|
|
|
|
namespace Beike\API\Controllers;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Beike\Shop\Http\Resources\CustomerResource;
|
|
|
|
class AuthController extends Controller
|
|
{
|
|
/**
|
|
* Create a new AuthController instance.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct()
|
|
{
|
|
// $this->middleware('auth:api', ['except' => ['login']]);
|
|
}
|
|
|
|
/**
|
|
* Get a JWT via given credentials.
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function login()
|
|
{
|
|
$credentials = request(['email', 'password']);
|
|
|
|
if (! $token = auth('api_customer')->attempt($credentials)) {
|
|
return response()->json(['error' => 'Unauthorized'], 401);
|
|
}
|
|
|
|
return $this->respondWithToken($token);
|
|
}
|
|
|
|
/**
|
|
* Get the authenticated User.
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function me()
|
|
{
|
|
$customer = auth('api_customer')->user();
|
|
|
|
return response()->json(new CustomerResource($customer));
|
|
}
|
|
|
|
/**
|
|
* Log the user out (Invalidate the token).
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function logout()
|
|
{
|
|
auth('api_customer')->logout();
|
|
|
|
return response()->json(['message' => 'Successfully logged out']);
|
|
}
|
|
|
|
/**
|
|
* Refresh a token.
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function refresh()
|
|
{
|
|
return $this->respondWithToken(auth('api_customer')->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' => auth('api_customer')->factory()->getTTL() * 60,
|
|
]);
|
|
}
|
|
}
|