You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
43 lines
1.4 KiB
43 lines
1.4 KiB
<?php
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use App\Http\Controllers\Api\BaseAuthApiController as BaseAuthApiController;
|
|
|
|
class AuthApiController extends BaseAuthApiController
|
|
{
|
|
//
|
|
public function login(Request $request)
|
|
{
|
|
$validator = \Illuminate\Support\Facades\Validator::make($request->all(), [
|
|
'username' => 'required|email',
|
|
'password' => 'required'
|
|
]);
|
|
if($validator->fails()){
|
|
return $this->sendError('Validation Error.', $validator->errors());
|
|
}
|
|
|
|
if (!Auth::attempt(['email' => $request->username, 'password' => $request->password])) {
|
|
return $this->sendError('Unauthorised.', ['error' => 'Unauthorised']);
|
|
}
|
|
$user = \App\Models\User::where('email', $request->username)->first();
|
|
|
|
if (empty($user)) {
|
|
$this->sendError('Error: ', ['error' => 'Email invalid']);
|
|
}
|
|
|
|
// Creating a token without scopes...
|
|
$token = $user->createToken($user->id . ' token ' . time(), ['*'])->accessToken;
|
|
|
|
$data['access_token'] = $token;
|
|
$data['token_type'] = 'Bearer';
|
|
$data['expires_in'] = 1296000;
|
|
$data['refresh_token'] = $token;
|
|
|
|
return $this->sendResponse($data, 'User login successfully.');
|
|
// return response()->json($data, 200);
|
|
}
|
|
}
|
|
|