Files
phpvms/app/Http/Controllers/Auth/RegisterController.php
2017-09-30 11:10:56 +02:00

102 lines
2.7 KiB
PHP
Executable File

<?php
namespace App\Http\Controllers\Auth;
use Validator;
use App\Models\Airport;
use App\Models\Airline;
use App\Services\PilotService;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\RegistersUsers;
use Illuminate\Http\Request;
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;
/**
* Where to redirect users after login / registration.
*
* @var string
*/
protected $redirectTo = '/';
public function showRegistrationForm()
{
$airports = Airport::all();
$airlines = Airline::all();
return $this->view('auth.register', [
'airports' => $airports,
'airlines' => $airlines,
]);
}
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest');
}
/**
* 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, [
'name' => 'required|max:255',
'email' => 'required|email|max:255|unique:users',
'airline' => 'required',
'home_airport' => 'required',
'password' => 'required|min:5|confirmed',
]);
}
/**
* Get a validator for an incoming registration request.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function create(array $data)
{
# First, validate the posted data
$this->validate(request(), [
'name' => 'required',
'email' => 'required|email',
'airline' => 'required',
'home_airport' => 'required',
'password' => 'required|confirmed'
]);
# Let's call the service
$pilotService = app('App\Services\PilotService');
# Let's tell the service to create the pilot
if($p = $pilotService->createPilot($data))
{
//return $this->view('auth.registered');
return $p;
}
# I'm not sure if we really need to add the error something if createPilot fails?
}
}