app/Http/Controllers/Api/ApiDeviceLoginController.php
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use Illuminate\Validation\ValidationException;
class ApiDeviceLoginController extends Controller
{
/**
* Device Login
*
* Create a new device token for the user.
* Otherwise we fall back to sanctum's default auth methodology.
*
* @return \Illuminate\Http\JsonResponse
*/
public function create(Request $request)
{
$request->validate([
'email' => 'required|email',
'password' => 'required',
'device_name' => 'required',
]);
$user = User::where('email', $request->email)->first();
if (! $user || ! Hash::check($request->password, $user->password)) {
throw ValidationException::withMessages([
'email' => [
'The provided credentials are incorrect.',
],
]);
}
return response()->json([
'data' => [
'token' => $user->createToken($request->device_name)->plainTextToken,
],
]);
}
}