добавлен механизм регистрации и авторизации
This commit is contained in:
55
app/Http/Controllers/UsersController.php
Normal file
55
app/Http/Controllers/UsersController.php
Normal 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!'];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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']);
|
||||||
Reference in New Issue
Block a user