main-backend/php_code/app/Http/Controllers/UsersController.php
2026-06-02 09:25:58 +00:00

248 lines
8.3 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Utilities\ApiCalls;
use App\Utilities\SmsLibrary;
use Session;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Mail;
use App\Mail\UserAccountsMail;
use App\Mail\PasswordResetMail;
use Illuminate\Support\Str;
class UsersController extends Controller
{
public function index(){
$data = [
'page_title' => 'Users Page '
];
return view('users.index', $data);
}
public function reset(){
$data = [
'page_title' => 'Password Reset Page'
];
return view('user-auth.reset', $data);
}
public function check_reset_email(Request $request){
// code...
// dd('foo bar');
$url = "user_mgt/get_user_by_user_id.php";
$user_id = "34ba702b-18f8-4d85-948d-8c55e8500f32";
$data = json_encode([
'user_id' => "34ba702b-18f8-4d85-948d-8c55e8500f32",// $id,
'api_token' => env('LUPMISAPIKEY')// make the API token a constant
]);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
// dd($result);
$recipientEmail = $result['data']['email'];
$fullname = $result['data']['full_name'];
$phone = $result['data']['phone'];
//send reset link email
//baduhupir@mailinator.com
$reset_link = env('APP_URL') . "/reset-auth/" . $user_id;
Mail::to($recipientEmail)->send(new PasswordResetMail($fullname, $reset_link));
return redirect(url('reset-notice')); //get
// return redirect(url('new-password-form'));
}
public function reset_notice(Request $request){
return view('user-auth.email-notice');
}
public function show_new_passform(Request $request){
// code...show_new_passform
// dd('foo bar show new pass');
dump($request->all());
$data = [
'page_title' => 'New Password Form'
];
return view('user-auth.password', $data);
}
public function handle_reset(Request $request){
// code...show_new_passform
// dd('foo bar handle reset');
return redirect(url('reset-success')); //get
}
public function reset_success(Request $request){
// code...show_new_passform
// dd('foo bar handle reset');
$data = [
'page_title' => 'New Password Success'
];
return view('user-auth.password-success', $data);
}
public function edit($id){
$url = "user_mgt/get_user_by_user_id.php";
$data = json_encode([
'user_id' => $id,
'api_token' => env('LUPMISAPIKEY')// make the API token a constant
]);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
$data = [
'page_title' => 'User Edit'
];
if (request()->expectsJson()) {
return response()->json($result);
}
return view('users.edit', $data);
}
public function show($id){
$url = "user_mgt/get_user_by_user_id.php";
$data = json_encode([
'user_id' => $id,
'api_token' => env('LUPMISAPIKEY')// make the API token a constant
]);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
if (request()->expectsJson()) {
return response()->json($result);
}
$data = [
'page_title' => 'User Profile',
'user' => $result
];
return view('admin.user-show', $data);
}
public function getprofile_json(){
$user_id = session('current_user.user_id');
$url = "user_mgt/get_user_by_user_id.php";
// dd($user_id);
$data = json_encode([
'user_id' => $user_id,
'api_token' => env('LUPMISAPIKEY')// make the API token a constant
]);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
if ($result['success'] == true) {
// code...
return response()->json(['code' => 1, 'user_details' => $result['data']]);
}
else{
return response()->json(['code' => 3, 'msg' => 'Your request could not be handled at this time']);
}
}
public function store(Request $request){
$url = "user_mgt/add_usr_user.php";
// return ['success' => true];
// $password = ApiCalls::generatePassword(10);
$password = $randomString = Str::random(10);
$data = json_encode([
'full_name' => $request['full_name'],
'username' => $request['username'],
'ua_position' => $request['ua_position'],
'email' => $request['email'],
'title' => $request['title'],
'allowed_apps' => implode(", ", $request['allowed_apps']),
'is_password_changed' => false,
'password_hint' => 'none',
'phone' => $request['phone'],
'gender' => $request['gender'],
'user_type' => $request['user_type'],
'pass' => $password,
'region_id' => $request['region_id'],
'district_id' => $request['districtid'],
'api_token' => env('LUPMISAPIKEY'), //'1c46538c712e9b5b' // make the API token a constant
]);
// dd($data);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
\Log::info("Your Password is $password");
$recipientEmail = 'recipient@example.com';
Mail::to($recipientEmail)->send(new UserAccountsMail($password, $request->username));
//dd('Email sent!');
$sms_message = "Hello $request->full_name your LUPMIS account has been successfully created\n";
$sms_message .= "Username : . $request->username \n";
$sms_message .= "Password : $password\n";
$sms_message .= 'Login URL : https://lupmis4luspa.org';
$sms_data = [
'recipient' => $request['phone'],
'message' => $sms_message
];
#$sms_result = SmsLibrary::SendMnotitySms($sms_data); // will send this the API
\Log::info("SMS Body : $sms_message");
#\Log::info("SMS API Response : $sms_result");
if (request()->expectsJson()) {
return response()->json($result);
}
}
public function update(Request $request){
$url = "user_mgt/update_usr_user.php";
// return ['success' => true];
// dd($request->all());
$user_data = [
'full_name' => $request['full_name'],
'username' => $request['username'],
'ua_position' => $request['ua_position'],
'user_id' => $request['user_id'],
'email' => $request['email'],
'title' => $request['title'],
'allowed_apps' => implode(", ", $request['allowed_apps']),
'phone' => $request['phone'],
'gender' => $request['gender'],
'user_type' => 'District User',
'api_token' => env('LUPMISAPIKEY'),
];
if ($request->has('expire_password')) {
$user_data['is_password_changed'] = 'NO';
}
$data = json_encode($user_data);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
// dd($result);
// return response()->json($result);
if ($request->expectsJson()) {
return response()->json($result);
}
}
public function profileupdate(Request $request){
$url = "user_mgt/update_usr_user.php";
// return ['success' => true];
// dd($request->all());
$user_data = [
'full_name' => $request['full_name'],
'username' => $request['username'],
'user_id' => $request['user_id'],
'email' => $request['email'],
'phone' => $request['phone'],
'gender' => $request['gender'],
'api_token' => env('LUPMISAPIKEY'),
];
if ($request->filled('password')) {
$user_data['password'] = $request->password;
}
$data = json_encode($user_data);
$result = ApiCalls::CurlPost($data, $url);
$result = json_decode($result, true);
if (request()->expectsJson()) {
return response()->json($result);
}
}
}