144 lines
4.1 KiB
PHP
144 lines
4.1 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Auth\Events\PasswordReset;
|
|
use Auth;
|
|
use App\Models\User;
|
|
use App\Utility\SmsUtility;
|
|
use Hash;
|
|
|
|
class OTPVerificationController extends Controller
|
|
{
|
|
/**
|
|
* Display a listing of the resource.
|
|
*
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function verification(Request $request){
|
|
if (Auth::check() && Auth::user()->email_verified_at == null) {
|
|
return view('otp_systems.frontend.user_verification');
|
|
}
|
|
else {
|
|
flash('You have already verified your number')->warning();
|
|
return redirect()->route('home');
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @param \Illuminate\Http\Request $request
|
|
* @param int $id
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
|
|
public function verify_phone(Request $request){
|
|
$user = Auth::user();
|
|
if ($user->verification_code == $request->verification_code) {
|
|
$user->email_verified_at = date('Y-m-d h:m:s');
|
|
$user->save();
|
|
|
|
flash('Your phone number has been verified successfully')->success();
|
|
return redirect()->route('home');
|
|
}
|
|
else{
|
|
flash('Invalid Code')->error();
|
|
return back();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param \Illuminate\Http\Request $request
|
|
* @param int $id
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
|
|
public function resend_verificcation_code(Request $request){
|
|
$user = Auth::user();
|
|
$user->verification_code = rand(100000,999999);
|
|
$user->save();
|
|
SmsUtility::phone_number_verification($user);
|
|
|
|
return back();
|
|
}
|
|
|
|
/**
|
|
* @param \Illuminate\Http\Request $request
|
|
* @param int $id
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
|
|
|
|
public function reset_password_with_code(Request $request)
|
|
{
|
|
$phone = "+{$request['country_code']}{$request['phone']}";
|
|
|
|
if (($user = User::where('phone', $phone)->where('verification_code', $request->code)->first()) != null) {
|
|
if ($request->password == $request->password_confirmation) {
|
|
$user->password = Hash::make($request->password);
|
|
$user->email_verified_at = date('Y-m-d h:m:s');
|
|
$user->save();
|
|
event(new PasswordReset($user));
|
|
auth()->login($user, true);
|
|
|
|
if (auth()->user()->user_type == 'admin' || auth()->user()->user_type == 'staff') {
|
|
flash("Password has been reset successfully")->success();
|
|
return redirect()->route('admin.dashboard');
|
|
}
|
|
flash("Password has been reset successfully")->success();
|
|
return redirect()->route('home');
|
|
} else {
|
|
flash("Password and confirm password didn't match")->warning();
|
|
return view('otp_systems.frontend.auth.passwords.reset_with_phone');
|
|
}
|
|
} else {
|
|
flash("Verification code mismatch")->error();
|
|
return view('otp_systems.frontend.auth.passwords.reset_with_phone');
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @param User $user
|
|
* @return void
|
|
*/
|
|
|
|
public function send_code($user){
|
|
SmsUtility::phone_number_verification($user);
|
|
}
|
|
|
|
/**
|
|
* @param Order $order
|
|
* @return void
|
|
*/
|
|
public function send_order_code($order){
|
|
$phone = json_decode($order->shipping_address)->phone;
|
|
if($phone != null){
|
|
SmsUtility::order_placement($phone, $order);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param Order $order
|
|
* @return void
|
|
*/
|
|
public function send_delivery_status($order){
|
|
$phone = json_decode($order->shipping_address)->phone;
|
|
if($phone != null){
|
|
SmsUtility::delivery_status_change($phone, $order);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param Order $order
|
|
* @return void
|
|
*/
|
|
public function send_payment_status($order){
|
|
$phone = json_decode($order->shipping_address)->phone;
|
|
if($phone != null){
|
|
SmsUtility::payment_status_change($phone, $order);
|
|
}
|
|
}
|
|
}
|