Attendize/app/Http/Controllers/UserSignupController.php

103 lines
3.0 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Attendize\Utils;
use App\Models\Account;
use App\Models\User;
use Illuminate\Contracts\Auth\Guard;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Mail;
class UserSignupController extends Controller
{
protected $auth;
public function __construct(Guard $auth)
{
if (Account::count() > 0 && !Utils::isAttendize()) {
return redirect()->route('login');
}
$this->auth = $auth;
$this->middleware('guest');
}
public function showSignup()
{
$is_attendize = Utils::isAttendize();
return view('Public.LoginAndRegister.Signup', compact('is_attendize'));
}
/**
* Creates an account.
*
* @param Request $request
*
* @return Redirect
*/
public function postSignup(Request $request)
{
$is_attendize = Utils::isAttendize();
$this->validate($request, [
'email' => 'required|email|unique:users',
'password' => 'required|min:8|confirmed',
'first_name' => 'required',
'terms_agreed' => $is_attendize ? 'required' : '',
]);
$account_data = $request->only(['email', 'first_name', 'last_name']);
$account_data['currency_id'] = config('attendize.default_currency');
$account_data['timezone_id'] = config('attendize.default_timezone');
$account = Account::create($account_data);
$user = new User();
$user_data = $request->only(['email', 'first_name', 'last_name']);
$user_data['password'] = Hash::make($request->get('password'));
$user_data['account_id'] = $account->id;
$user_data['is_parent'] = 1;
$user_data['is_registered'] = 1;
$user = User::create($user_data);
if ($is_attendize) {
// TODO: Do this async?
Mail::send('Emails.ConfirmEmail',
['first_name' => $user->first_name, 'confirmation_code' => $user->confirmation_code],
function ($message) use ($request) {
$message->to($request->get('email'), $request->get('first_name'))
->subject(trans("Email.attendize_register"));
});
}
session()->flash('message', 'Success! You can now login.');
return redirect('login');
}
/**
* Confirm a user email
*
* @param $confirmation_code
* @return mixed
*/
public function confirmEmail($confirmation_code)
{
$user = User::whereConfirmationCode($confirmation_code)->first();
if (!$user) {
return view('Public.Errors.Generic', [
'message' => trans("Controllers.confirmation_malformed"),
]);
}
$user->is_confirmed = 1;
$user->confirmation_code = null;
$user->save();
session()->flash('message', trans("Controllers.confirmation_successful"));
return redirect()->route('login');
}
}