* @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, ]); } }