1
0
forked from s421507/eOSP2
eOSP2/app/Http/Controllers/RegistrationController.php

98 lines
2.8 KiB
PHP
Raw Normal View History

2019-07-11 23:55:51 +02:00
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Input;
2019-07-11 23:55:51 +02:00
use Illuminate\Http\Request;
2019-08-30 02:12:27 +02:00
use App\User;
use Mail;
use App\Rules\Pesel;
2019-07-11 23:55:51 +02:00
/* 'phoneNumber' => 'required|regex:/^([0-9\s\-\+\(\)]*)$/|min:9' */
2019-08-30 02:12:27 +02:00
class RegistrationController extends Controller
{
public function create()
{
return view('register');
}
public function store()
{
$this->validate(request(), [
'name' => 'required|alpha|min:3|max:45',
'surname' => 'required|alpha|min:3|max:45',
'PESEL' => new Pesel,
'phoneNumber' => 'required|digits:9',
'email' => 'required|email|unique:users',
'password' => 'required|confirmed|min:6',
],
[
'required' => ':attribute jest wymagany(e).',
'min' => ':attribute musi mieć przynajmniej :min znaki.',
'max' => ':attribute musi mieć nie więcej niż :max znaków.',
'alpha' => ':attribute może zawierać tylko litery.',
'alpha_num' => ':attribute może zawierać tylko litery i cyfry.',
'digits' => ':attribute musi składać się z :digits cyfr.',
'unique' =>':attribute jest już zajęty.',
'confirmed' =>':attribute się nie zgadza.',
'email' => 'Niepoprawny adres e-mail.'
2019-08-30 02:12:27 +02:00
]);
$request = request();
$confirmation_code = str_random(30);
$user = User::create([
'password' => $request-> password,
'email' => $request-> email,
'name' => $request-> name,
'surname' => $request-> surname,
'PESEL' => $request-> PESEL,
'phoneNumber' => $request-> phoneNumber,
'functionID' => 1,
'degreeID' => 1,
'number' => 'ABC123',
'confirmation_code' => $confirmation_code
]);
2019-08-30 02:12:27 +02:00
Mail::send('emails.verify', compact('confirmation_code'), function($message) {
$message->to(Input::get('email'), Input::get('name'))->subject('Weryfikacja adresu e-mail');
});
//Flash::message('Thanks for signing up! Please check your email.');
2019-08-30 02:12:27 +02:00
auth()->login($user);
return redirect()->to('/jednostka');
}
public function confirm($confirmation_code)
{
if( ! $confirmation_code)
{
throw new InvalidConfirmationCodeException;
}
$user = User::whereConfirmationCode($confirmation_code)->first();
if ( ! $user)
{
throw new InvalidConfirmationCodeException;
}
$user->confirmed = 1;
$user->confirmation_code = null;
$user->email_verified_at = now();
$user->save();
//Flash::message('You have successfully verified your account.');
return redirect()->to('/jednostka');
}
2019-08-30 02:12:27 +02:00
}