added User management
This commit is contained in:
103
app/Http/Controllers/ClientUsersController.php
Normal file
103
app/Http/Controllers/ClientUsersController.php
Normal 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!']);
|
||||
}
|
||||
}
|
||||
@@ -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']);
|
||||
|
||||
@@ -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();
|
||||
|
||||
Reference in New Issue
Block a user