добавлен механизм регистрации и авторизации

This commit is contained in:
xrei
2025-11-19 17:54:27 +00:00
parent 821f8c6132
commit beecb48c94
3 changed files with 63 additions and 2 deletions

View File

@@ -0,0 +1,55 @@
<?php
namespace App\Http\Controllers;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Validation\ValidationException;
class UsersController extends Controller
{
public function create(Request $request)
{
$user = new User();
$name = $request->get('name');
$email = $request->get('email');
$password = Hash::make($request->get('password'));
$user->name = $name;
$user->email = $email;
$user->password = $password;
$user->save();
$token = $user->createToken('frontend');
return ['token' => $token->plainTextToken];
}
public function auth(Request $request)
{
$request->validate([
'email' => 'required|email',
'password' => 'required',
]);
$user = User::where('email', $request->email)->first();
if (! $user || ! Hash::check($request->password, $user->password)) {
// throw ValidationException::withMessages([
// 'response' => ['Данные для входа неверны.'],
// ]);
return ['response' => 'Данные для входа неверны.'];
}
$token = $user->createToken('frontend');
return ['response' => 'Успешно!','token' => $token->plainTextToken];
// if (Auth::attempt($credentials)) {
// return ['response' => 'Logged in!'];
// }
// return ['response' => 'Error!'];
}
}

View File

@@ -6,11 +6,12 @@ namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable; use Illuminate\Notifications\Notifiable;
use Laravel\Sanctum\HasApiTokens;
class User extends Authenticatable class User extends Authenticatable
{ {
/** @use HasFactory<\Database\Factories\UserFactory> */ /** @use HasFactory<\Database\Factories\UserFactory> */
use HasFactory, Notifiable; use HasApiTokens, HasFactory, Notifiable;
/** /**
* The attributes that are mass assignable. * The attributes that are mass assignable.
@@ -45,4 +46,5 @@ class User extends Authenticatable
'password' => 'hashed', 'password' => 'hashed',
]; ];
} }
} }

View File

@@ -1,5 +1,6 @@
<?php <?php
use App\Http\Controllers\UsersController;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Route; use Illuminate\Support\Facades\Route;
use App\Http\Controllers\CloudServiceController; use App\Http\Controllers\CloudServiceController;
@@ -11,4 +12,7 @@ Route::get('/user', function (Request $request) {
// Route::get('projects', function () { return response()->json(['test' => 'test']);}); // Route::get('projects', function () { return response()->json(['test' => 'test']);});
Route::get('/cloudServices', [CloudServiceController::class, 'index']); Route::get('/cloudServices', [CloudServiceController::class, 'index']);
Route::post('cloudServices', [CloudServiceController::class, 'create']); Route::post('cloudServices', [CloudServiceController::class, 'create']);
Route::post('users', [UsersController::class, 'create']);
Route::post('login', [UsersController::class, 'auth']);