user(); if(!$user->email_verified_at) { return response()->json(['message' => 'Please verify your email address before verifying your phone number'], 400); } $account = $user->company()->account; if(!$this->checkPhoneValidity($request->phone)) { return response()->json(['message' => 'This phone number is not supported'], 400); } if (MultiDB::hasPhoneNumber($request->phone)) { return response()->json(['message' => 'This phone number has already been verified with another account'], 400); } $sid = config('ninja.twilio_account_sid'); $token = config('ninja.twilio_auth_token'); $twilio = new Client($sid, $token); try { $verification = $twilio->verify ->v2 ->services(config('ninja.twilio_verify_sid')) ->verifications ->create($request->phone, "sms"); } catch(\Exception $e) { return response()->json(['message' => 'Invalid phone number please use + country code + number ie. +15552343334'], 400); } $account->account_sms_verification_code = $verification->sid; $account->account_sms_verification_number = $request->phone; $account->save(); return response()->json(['message' => 'Code sent.'], 200); } private function checkPhoneValidity($phone) { foreach($this->invalid_codes as $code){ if(stripos($phone, $code) !== false) { return false; } return true; } } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\JsonResponse; */ public function confirm(ConfirmSmsRequest $request) { /** @var \App\Models\User $user */ $user = auth()->user(); $account = $user->company()->account; $sid = config('ninja.twilio_account_sid'); $token = config('ninja.twilio_auth_token'); $twilio = new Client($sid, $token); $verification_check = $twilio->verify ->v2 ->services(config('ninja.twilio_verify_sid')) ->verificationChecks ->create([ "to" => $account->account_sms_verification_number, "code" => $request->code ]); if ($verification_check->status == 'approved') { $account->account_sms_verified = true; $account->save(); /** @var \App\Models\User $user */ $user = auth()->user(); $user->phone = $account->account_sms_verification_number; $user->verified_phone_number = true; $user->save(); return response()->json(['message' => 'SMS verified'], 200); } return response()->json(['message' => 'SMS not verified'], 400); } /** * generate2faResetCode * * @return \Illuminate\Http\JsonResponse; */ public function generate2faResetCode(Generate2faRequest $request) { nlog($request->all()); nlog($request->headers()); $user = User::where('email', $request->email)->first(); if (!$user) { return response()->json(['message' => 'Unable to retrieve user.'], 400); } if(!$user->email_verified_at) { return response()->json(['message' => 'Please verify your email address before verifying your phone number'], 400); } if(!$user->first_name || !$user->last_name) { return response()->json(['message' => 'Please update your first and/or last name in the User Details before verifying your number.'], 400); } if (!$user->phone || $user->phone == '') { return response()->json(['message' => 'User found, but no valid phone number on file, please contact support.'], 400); } $sid = config('ninja.twilio_account_sid'); $token = config('ninja.twilio_auth_token'); $twilio = new Client($sid, $token); try { $verification = $twilio->verify ->v2 ->services(config('ninja.twilio_verify_sid')) ->verifications ->create($user->phone, "sms"); } catch(\Exception $e) { return response()->json(['message' => 'Invalid phone number on file, we are unable to reset. Please contact support.'], 400); } $user->sms_verification_code = $verification->sid; $user->save(); return response()->json(['message' => 'Code sent.'], 200); } /** * confirm2faResetCode * * @param Confirm2faRequest $request * @return \Illuminate\Http\JsonResponse; */ public function confirm2faResetCode(Confirm2faRequest $request) { $user = User::where('email', $request->email)->first(); if (!$user) { return response()->json(['message' => 'Unable to retrieve user.'], 400); } $sid = config('ninja.twilio_account_sid'); $token = config('ninja.twilio_auth_token'); $twilio = new Client($sid, $token); $verification_check = $twilio->verify ->v2 ->services(config('ninja.twilio_verify_sid')) ->verificationChecks ->create([ "to" => $user->phone, "code" => $request->code ]); if ($verification_check->status == 'approved') { if ($request->query('validate_only') == 'true') { $user->verified_phone_number = true; $user->save(); return response()->json(['message' => 'SMS verified'], 200); } $user->google_2fa_secret = ''; $user->sms_verification_code = ''; $user->save(); return response()->json(['message' => 'SMS verified, 2FA disabled.'], 200); } return response()->json(['message' => 'SMS not verified.'], 400); } // public function validatePhoneNumber() // { // $sid = config('ninja.twilio_account_sid'); // $token = config('ninja.twilio_auth_token'); // $twilio = new Client($sid, $token); // $phone_number = $twilio->lookups->v1->phoneNumbers("0417918829") // ->fetch(["countryCode" => "AU"]); // print($phone_number); // } }