Fixes for emails; send user registered/pending depending on state

This commit is contained in:
Nabeel Shahzad
2017-12-22 12:46:46 -06:00
parent 74316218bc
commit 161623c85e
42 changed files with 215 additions and 153 deletions

View File

@@ -4,6 +4,7 @@ namespace App\Services;
use App\Events\UserRegistered;
use App\Facades\Utils;
use App\Models\Enums\PilotState;
use App\Models\User;
use App\Models\Rank;
use App\Models\Role;
@@ -18,29 +19,19 @@ class UserService extends BaseService
/**
* Register a pilot
* @param array $data
* @param User $user
* @return mixed
*/
public function createPilot(array $data)
public function createPilot(User $user)
{
$opts = [
'name' => $data['name'],
'email' => $data['email'],
'api_key' => Utils::generateApiKey(),
'airline_id' => $data['airline'],
'home_airport_id' => $data['home_airport'],
'curr_airport_id' => $data['home_airport'],
'password' => Hash::make($data['password'])
];
# Determine if we want to auto accept
if(setting('pilot.auto_accept') === true) {
$opts['status'] = config('enums.states.ACTIVE');
$user->state = PilotState::ACTIVE;
} else {
$opts['status'] = config('enums.states.PENDING');
$user->state = PilotState::PENDING;
}
$user = User::create($opts);
$user->save();
# Attach the user roles
$role = Role::where('name', 'user')->first();
@@ -49,6 +40,8 @@ class UserService extends BaseService
# Let's check their rank
$this->calculatePilotRank($user);
$user->refresh();
event(new UserRegistered($user));
return $user;