mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-15 07:33:04 +01:00
250 lines
8.1 KiB
PHP
250 lines
8.1 KiB
PHP
<?php
|
|
/**
|
|
* Invoice Ninja (https://invoiceninja.com).
|
|
*
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
*
|
|
* @copyright Copyright (c) 2024. Invoice Ninja LLC (https://invoiceninja.com)
|
|
*
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
|
*/
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Http\Requests\Twilio\Confirm2faRequest;
|
|
use App\Http\Requests\Twilio\ConfirmSmsRequest;
|
|
use App\Http\Requests\Twilio\Generate2faRequest;
|
|
use App\Http\Requests\Twilio\GenerateSmsRequest;
|
|
use App\Libraries\MultiDB;
|
|
use App\Models\User;
|
|
use Twilio\Rest\Client;
|
|
|
|
class TwilioController extends BaseController
|
|
{
|
|
private array $invalid_codes = [
|
|
'+21',
|
|
'+17152567760',
|
|
];
|
|
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Display a listing of the resource.
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Response;
|
|
*/
|
|
public function generate(GenerateSmsRequest $request)
|
|
{
|
|
/** @var \App\Models\User $user */
|
|
$user = auth()->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|\Illuminate\Http\Response;
|
|
*/
|
|
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();
|
|
|
|
if (class_exists(\Modules\Admin\Jobs\Account\UserQualityCheck::class)) {
|
|
\Modules\Admin\Jobs\Account\UserQualityCheck::dispatch($user, $user->company()->db);
|
|
}
|
|
|
|
return response()->json(['message' => 'SMS verified'], 200);
|
|
}
|
|
|
|
|
|
return response()->json(['message' => 'SMS not verified'], 400);
|
|
}
|
|
|
|
/**
|
|
* generate2faResetCode
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Response;
|
|
*/
|
|
public function generate2faResetCode(Generate2faRequest $request)
|
|
{
|
|
nlog($request->all());
|
|
|
|
$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 || empty($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|\Illuminate\Http\Response;
|
|
*/
|
|
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);
|
|
// }
|
|
}
|