flexisip-account-manager/flexiapi/app/Http/Controllers/Account/RegisterController.php
Timothée Jaussoin 30fcf9792f Update wording
Send a confirmation email when the password is set for the first time
Remove the API link from the menu and move it to the footer
Allow different domains to be set in the POST /api/accounts endpoints + related tests
Cleanup the API tests
Update the dependencies
2020-09-14 11:55:07 +02:00

125 lines
3.8 KiB
PHP

<?php
namespace App\Http\Controllers\Account;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Str;
use Illuminate\Support\Facades\Mail;
use Carbon\Carbon;
use App\Account;
use App\Alias;
use App\Rules\SIP;
use App\Rules\WithoutSpaces;
use App\Helpers\Utils;
use App\Libraries\OvhSMS;
use App\Mail\RegisterConfirmation;
use App\Mail\NewsletterRegistration;
class RegisterController extends Controller
{
private $emailCodeSize = 14;
public function register(Request $request)
{
if (config('app.phone_authentication') == false) {
return redirect()->route('account.register.email');
}
return view('account.register');
}
public function registerPhone(Request $request)
{
return view('account.register.phone', [
'domain' => '@' . config('app.sip_domain')
]);
}
public function registerEmail(Request $request)
{
return view('account.register.email', [
'domain' => '@' . config('app.sip_domain')
]);
}
public function storeEmail(Request $request)
{
$request->validate([
'terms' => 'accepted',
'username' => [
'required', 'unique:external.accounts,username', 'filled', new WithoutSpaces
],
'g-recaptcha-response' => 'required|captcha',
'email' => 'required|email|confirmed'
]);
$account = new Account;
$account->username = $request->get('username');
$account->email = $request->get('email');
$account->activated = false;
$account->domain = config('app.sip_domain');
$account->ip_address = $request->ip();
$account->creation_time = Carbon::now();
$account->user_agent = config('app.name');
$account->save();
$account->confirmation_key = Str::random($this->emailCodeSize);
$account->save();
if (!empty(config('app.newsletter_registration_address'))
&& $request->has('newsletter')) {
Mail::to(config('app.newsletter_registration_address'))->send(new NewsletterRegistration($account));
}
Mail::to($account)->send(new RegisterConfirmation($account));
return view('account.authenticate.email', [
'account' => $account
]);
}
public function storePhone(Request $request)
{
$request->validate([
'terms' =>'accepted',
'username' => 'unique:external.accounts,username|nullable|filled',
'phone' => [
'required', 'unique:external.aliases,alias',
'unique:external.accounts,username',
new WithoutSpaces, 'starts_with:+', 'phone:AUTO'
],
'g-recaptcha-response' => 'required|captcha',
]);
$account = new Account;
$account->username = !empty($request->get('username'))
? $request->get('username')
: $request->get('phone');
$account->email = $request->get('email');
$account->activated = false;
$account->domain = config('app.sip_domain');
$account->ip_address = $request->ip();
$account->creation_time = Carbon::now();
$account->user_agent = config('app.name');
$account->save();
$alias = new Alias;
$alias->alias = $request->get('phone');
$alias->domain = config('app.sip_domain');
$alias->account_id = $account->id;
$alias->save();
$account->confirmation_key = Utils::generatePin();
$account->save();
$ovhSMS = new OvhSMS;
$ovhSMS->send($request->get('phone'), 'Your '.config('app.name').' validation code is '.$account->confirmation_key);
return view('account.authenticate.phone', [
'account' => $account
]);
}
}