added User management

This commit is contained in:
Kwesi Banson Jnr
2026-04-24 12:09:36 +00:00
parent 16f2dbbdb6
commit 757f908404
16 changed files with 1156 additions and 366 deletions

View File

@@ -0,0 +1,103 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models;
use App\Utilities\ApiCalls;
use Session;
use Illuminate\Pagination\LengthAwarePaginator;
use Illuminate\Support\Facades\Hash;
class ClientUsersController extends Controller
{
public function indexBak(){
$user_list = Models\ClientSession::get();
$data = [
'page_title' => 'Users',
];
return view('client-users.index', $data);
}
public function index()
{
$data = [
'page_title' => 'Users',
];
return view('client-users.index', $data);
}
// Read: Fetch data for the jQuery table
// public function fetch()
// {
// $sessions = Models\ClientSession::orderBy('id', 'desc')->paginate(5);
// return response()->json(['sessions' => $sessions]);
// }
public function fetch(Request $request)
{
$query = Models\ClientSession::query();
// Check if the search parameter has a value
if ($request->has('search') && !empty($request->search)) {
$search = $request->search;
$query->where(function($q) use ($search) {
$q->where('email', 'LIKE', "%{$search}%")
->orWhere('role', 'LIKE', "%{$search}%");
});
}
$sessions = $query->orderBy('id', 'desc')->paginate(5);
return response()->json(['sessions' => $sessions]);
}
// Create: Store a new record
public function store(Request $request)
{
$request->validate([
'email' => 'required|email|unique:client_sessions,email',
'role' => 'required|string',
'password' => 'required|string'
]);
$session = Models\ClientSession::create([
'email' => $request->email,
'role' => $request->role,
'password' => Hash::make($request->password)
]);
return response()->json(['status' => 'success', 'message' => 'User created successfully!']);
}
public function edit($id)
{
$session = Models\ClientSession::findOrFail($id);
return response()->json(['session' => $session]);
}
public function update(Request $request, $id)
{
$request->validate([
'email' => 'required|email|unique:client_sessions,email,' . $id,
'role' => 'required|string',
'password' => 'required|string'
]);
$session = Models\ClientSession::findOrFail($id);
$session->update([
'email' => $request->email,
'role' => $request->role,
'password' => Hash::make($request->password)
]);
return response()->json(['status' => 'success', 'message' => 'User updated successfully!']);
}
// Delete: Remove record
public function destroy($id)
{
Models\ClientSession::findOrFail($id)->delete();
return response()->json(['status' => 'success', 'message' => 'User deleted successfully!']);
}
}

View File

@@ -83,7 +83,6 @@ class ClientsLoginController extends Controller
$logged_in = '';
$client = Models\ClientSession::where('email', $request->email)->first();
// dd($client);
if ($client == false) {
return redirect()->back()->withErrors(['Invalid credentials']);
}
@@ -92,13 +91,14 @@ class ClientsLoginController extends Controller
$result_arr = json_decode($result, true);
$logged_in = $result_arr;
// dd($logged_in);
$request->session()->regenerate(true);
$request->session()->put('current_user.user_id', $logged_in['id']);
$request->session()->put('current_user.org_id', $logged_in['id']);
$request->session()->put('current_user.name', $logged_in['name']);
$request->session()->put('current_user.email', $logged_in['email']);
$request->session()->put('current_user.role', $client['role']);
$request->session()->put('current_user.phoneNumber', $logged_in['phoneNumber']);
$request->session()->put('current_user.status', $logged_in['status']);
$request->session()->put('current_user.createdAt', $logged_in['createdAt']);

View File

@@ -68,7 +68,7 @@ class ClientsTrafficController extends Controller
'sms_units_arr' => $sms_units_arr,
'balance_arr' => $balance_arr
];
return view('client-traffic.index-test', $data);
return view('client-traffic.index-main', $data);
}
public function indexTabulator(Request $request){
$client = new Client();