database-pertani-web/app/Http/Controllers/Api/AuthController.php
2026-02-20 17:04:36 +07:00

94 lines
2.5 KiB
PHP

<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Http\JsonResponse;
use Illuminate\Support\Facades\Hash;
use App\Models\User;
use App\Models\Profile;
class AuthController extends Controller
{
public function login(Request $request): JSONResponse
{
$credentials = $request->validate([
'email' => ['required', 'email'],
'password' => ['required', 'string'],
]);
if (!Auth::attempt($credentials)) {
return response()->json([
'message' => 'Email dan/atau password tidak sesuai'
], 401);
}
$user = Auth::user();
$user->tokens()->delete();
$token = $user->createToken('mobile-token')->plainTextToken;
return response()->json([
'access_token' => $token,
'token_type' => 'Bearer',
]);
}
public function signup(Request $request): JSONResponse
{
$credentials = $request->validate([
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'email'],
'password' => ['required', 'string', 'min:8', 'confirmed'],
'role' => ['string'],
]);
$user = User::create([
'name' => $credentials['name'],
'email' => $credentials['email'],
'password' => Hash::make($credentials['password']),
'role' => $credentials['role'],
]);
$profile = Profile::create([
'nama' => $credentials['name'],
'email' => $credentials['email'],
'role' => $credentials['role'],
'user_id' => $user->id,
]);
if (!Auth::attempt($credentials)) {
return response()->json([
'message' => 'Email dan/atau password tidak sesuai'
], 401);
}
$user = Auth::user();
$user->tokens()->delete();
$token = $user->createToken('mobile-token')->plainTextToken;
return response()->json([
'access_token' => $token,
'token_type' => 'Bearer',
]);
}
public function me(Request $request): JSONResponse
{
return response()->json($request->user());
}
public function logout(Request $request): JSONResponse
{
$request->user()->currentAccessToken()->delete();
return response()->json([
'message' => 'Berhasil logout',
]);
}
}