cms-laravel/app/Livewire/UserManagement/Create.php

145 lines
5.8 KiB
PHP

<?php
namespace App\Livewire\UserManagement;
use Livewire\Component;
use App\Services\ApiService;
use Illuminate\Support\Facades\Session;
use Illuminate\Support\Facades\Log;
class Create extends Component
{
public $username = '';
public $firstname = '';
public $lastname = '';
public $email = '';
public $role = '';
public $status = 'active';
public $password = '';
public $loading = false;
public $isGenerated = false;
public $errors = [];
protected $apiService;
public function boot(ApiService $apiService)
{
$this->apiService = $apiService;
}
public function mount()
{
// Check role-based access
$userInfo = Session::get('userInfo');
if (!$userInfo || $userInfo['role'] != 1) {
return redirect()->route('404');
}
}
public function create()
{
$this->loading = true;
$this->errors = [];
try {
$this->validate([
'username' => ['required', 'max:128', 'regex:/^[a-zA-Z0-9_@.ñÑ ]+$/'],
'firstname' => ['required', 'max:128', 'regex:/^[A-Za-z ñÑ-]+$/'],
'lastname' => ['required', 'max:128', 'regex:/^[A-Za-z ñÑ-]+$/'],
'email' => ['required', 'email', 'max:128', 'regex:/^[A-Za-z0-9@_.ñÑ ]+$/'],
'role' => ['required'],
'status' => ['required'],
'password' => ['required'],
], [
'username.required' => 'Username is required!',
'username.max' => 'Maximum character is 128.',
'username.regex' => 'Invalid Username.',
'firstname.required' => 'First Name is required!',
'firstname.max' => 'Maximum character is 128.',
'firstname.regex' => 'Invalid First Name.',
'lastname.required' => 'Last Name is required!',
'lastname.max' => 'Maximum character is 128.',
'lastname.regex' => 'Invalid Last Name.',
'email.required' => 'Email is required!',
'email.email' => 'Invalid Email Address.',
'email.max' => 'Maximum character is 128.',
'email.regex' => 'Invalid Email Address.',
'role.required' => 'Role is required!',
'status.required' => 'Status is required!',
'password.required' => 'Default Password is required!',
]);
$params = [
'username' => strtolower(trim($this->username)),
'firstname' => trim($this->firstname),
'lastname' => trim($this->lastname),
'email' => $this->email,
'role' => (int)$this->role,
'status' => $this->status,
'password' => $this->password,
];
$response = $this->apiService->post('admin', $params);
if ($response && isset($response['status']) && $response['status'] === 200) {
Session::flash('success', 'User account created successfully. Please send the login credentials to the user.');
Log::info('User created successfully', ['source' => 'UserManagementCreate']);
return redirect()->route('user-management');
}
} catch (\Illuminate\Validation\ValidationException $e) {
$this->errors = $e->errors();
Session::flash('error', 'Something went wrong creating new record: ' . implode(', ', array_merge(...array_values($e->errors()))));
Log::error('Validation failed', ['errors' => $e->errors(), 'source' => 'UserManagementCreate']);
} catch (\Exception $e) {
$errorMessage = '';
if ($e->getCode() === 422) {
$errors = json_decode($e->getMessage(), true)['data'] ?? [];
$errorMessage = 'Something went wrong creating new record: ';
if (!empty($errors['username'])) {
$errorMessage .= $errors['username'][0] . ' ';
}
if (!empty($errors['email'])) {
$errorMessage .= $errors['email'][0];
}
} else {
$errorMessage = 'Something went wrong creating new record: ' . $e->getMessage();
}
Session::flash('error', $errorMessage);
Log::error('Failed to create user', ['error' => $e->getMessage(), 'source' => 'UserManagementCreate']);
} finally {
$this->loading = false;
}
}
public function generatePassword()
{
$this->loading = true;
try {
// Note: React uses adminProfile to get admin_uuid, but for Create, we may not have it yet.
// Assuming the API accepts no admin_uuid for new users or uses a different endpoint.
$response = $this->apiService->post('generatePassword', []);
if ($response && isset($response['data']['password'])) {
$this->password = $response['data']['password'];
$this->isGenerated = true;
Session::flash('success', 'Password generated successfully.');
Log::info('Password generated', ['source' => 'UserManagementCreate']);
}
} catch (\Exception $e) {
Session::flash('error', 'Something went wrong generating password: ' . $e->getMessage());
Log::error('Failed to generate password', ['error' => $e->getMessage(), 'source' => 'UserManagementCreate']);
} finally {
$this->loading = false;
}
}
public function copyPassword()
{
$this->dispatchBrowserEvent('copy-password', ['password' => $this->password]);
}
public function render()
{
return view('livewire.user-management.create')->layout('layouts.app', ['title' => 'Add User']);
}
}