File: //var/www/html/punjabcabs/app/Http/Controllers/ProviderAuth/RegisterController.php
<?php
namespace App\Http\Controllers\ProviderAuth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\RegistersUsers;
use Illuminate\Support\Facades\Auth;
use Setting;
use Validator;
use App\Provider;
use App\ProviderService;
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 = '/provider/';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('provider.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, [
'first_name' => 'required|max:255',
'last_name' => 'required|max:255',
'phone_number' => 'required',
'country_code' => 'required',
'email' => 'required|email|max:255|unique:providers',
'password' => 'required|min:6|confirmed',
'service_type' => 'required',
'service_number' => 'required',
'service_model' => 'required',
]);
}
/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return Provider
*/
protected function create(array $data)
{
$Provider = Provider::create([
'first_name' => $data['first_name'],
'last_name' => $data['last_name'],
'email' => $data['email'],
'mobile' => $data['country_code'].$data['phone_number'],
'password' => bcrypt($data['password']),
]);
$provider_service = ProviderService::create([
'provider_id' => $Provider->id,
'service_type_id' => $data['service_type'],
'taxi_type' => 1,
'service_number' => $data['service_number'],
'service_model' => $data['service_model'],
]);
if(Setting::get('demo_mode', 0) == 1) {
$Provider->update(['status' => 'approved']);
$provider_service->update([
'status' => 'active',
]);
}
return $Provider;
}
/**
* Show the application registration form.
*
* @return \Illuminate\Http\Response
*/
public function showRegistrationForm()
{
return view('provider.auth.register');
}
/**
* Get the guard to be used during registration.
*
* @return \Illuminate\Contracts\Auth\StatefulGuard
*/
protected function guard()
{
return Auth::guard('provider');
}
}