@tykus Of course:
namespace App\Http\Controllers\Auth;
use App\User;
use App\Http\Controllers\Controller;
use App\UsersSettings;
use App\VerifyAccount;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Input;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;
class RegisterController extends Controller
{
/*
|--------------------------------------------------------------------------
| Register Controller
|--------------------------------------------------------------------------
|
| This controller handles the registration of new users as well as their
| validation and creation. By default this controller uses a trait to
| provide this functionality without requiring any additional code.
|
*/
use RegistersUsers;
private $user;
private $verifyToken;
public function __construct() {
$this->middleware('guest');
}
public function showRegistrationForm() {
return !Auth::check()
? view('admin.auth.register')
: redirect('admin');
}
public function processRegister() {
$data = Input::all();
$validator = $this->validator($data);
if(!$validator->passes() || !$this->create($data))
return view('admin.auth.register', [
'data' => $data,
'errors' => array_unique($validator->errors()->all())
]);
$this->createSettings();
$this->createVerification();
// TODO > Send mail with activation link
return view('admin.auth.register', ['success' => true]);
}
/**
* Get a validator for an incoming registration request.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function validator(array $data) {
return Validator::make($data, [
'username' => 'required|string|min:3|max:32|unique:users',
'email' => 'required|string|email|max:64|unique:users',
'password' => 'required|string|min:8|confirmed',
'eula' => 'required|string'
]);
}
/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return \App\User
*/
protected function create(array $data) {
$this->user = User::create([
'username' => $data['username'],
'email' => $data['email'],
'password' => bcrypt($data['password'], [
'cost' => 12
]),
]);
return $this->user;
}
private function createSettings() {
UsersSettings::create([
'user_id' => $this->user->id,
'gender' => null,
'firstname' => '',
'lastname' => '',
'street' => '',
'city' => '',
'zip' => '',
'phone' => ''
]);
}
private function createVerification() {
$this->verifyToken = VerifyAccount::create([
'user_id' => $this->user->id,
'code' => str_random(128),
'active' => true
])->code;
}
}