2017-06-09 02:28:26 +08:00
|
|
|
<?php
|
|
|
|
|
2017-06-11 09:10:31 +08:00
|
|
|
namespace App\Models;
|
2017-06-09 02:28:26 +08:00
|
|
|
|
2018-03-06 09:55:48 +08:00
|
|
|
use App\Models\Enums\JournalType;
|
2018-03-02 06:20:13 +08:00
|
|
|
use App\Models\Traits\JournalTrait;
|
2022-03-14 23:45:18 +08:00
|
|
|
use Illuminate\Database\Eloquent\Casts\Attribute;
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
2017-06-09 02:28:26 +08:00
|
|
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
2018-02-21 12:33:09 +08:00
|
|
|
use Illuminate\Notifications\Notifiable;
|
2017-12-16 02:36:13 +08:00
|
|
|
use Laratrust\Traits\LaratrustUserTrait;
|
2021-12-01 03:36:17 +08:00
|
|
|
use Staudenmeir\EloquentHasManyDeep\HasRelationships;
|
2017-06-09 02:28:26 +08:00
|
|
|
|
|
|
|
/**
|
2020-08-12 05:48:51 +08:00
|
|
|
* @property int id
|
|
|
|
* @property int pilot_id
|
|
|
|
* @property int airline_id
|
|
|
|
* @property string name
|
|
|
|
* @property string name_private Only first name, rest are initials
|
|
|
|
* @property string email
|
|
|
|
* @property string password
|
|
|
|
* @property string api_key
|
|
|
|
* @property mixed timezone
|
|
|
|
* @property string ident
|
|
|
|
* @property string curr_airport_id
|
|
|
|
* @property string home_airport_id
|
|
|
|
* @property string avatar
|
|
|
|
* @property Airline airline
|
|
|
|
* @property Flight[] flights
|
|
|
|
* @property int flight_time
|
|
|
|
* @property int transfer_time
|
|
|
|
* @property string remember_token
|
|
|
|
* @property \Carbon\Carbon created_at
|
|
|
|
* @property \Carbon\Carbon updated_at
|
|
|
|
* @property Rank rank
|
|
|
|
* @property Journal journal
|
|
|
|
* @property int rank_id
|
2021-06-04 22:51:59 +08:00
|
|
|
* @property string discord_id
|
2020-08-12 05:48:51 +08:00
|
|
|
* @property int state
|
2021-06-05 01:20:33 +08:00
|
|
|
* @property string last_ip
|
2020-08-12 05:48:51 +08:00
|
|
|
* @property bool opt_in
|
2021-05-05 21:56:28 +08:00
|
|
|
* @property Pirep[] pireps
|
2020-08-12 05:48:51 +08:00
|
|
|
* @property string last_pirep_id
|
2020-10-23 04:25:52 +08:00
|
|
|
* @property Pirep last_pirep
|
2020-08-12 05:48:51 +08:00
|
|
|
* @property UserFieldValue[] fields
|
2021-04-23 22:33:13 +08:00
|
|
|
* @property Role[] roles
|
|
|
|
* @property Subfleet[] subfleets
|
2021-12-01 03:36:17 +08:00
|
|
|
* @property TypeRating[] typeratings
|
2019-11-27 22:19:20 +08:00
|
|
|
*
|
2019-12-22 12:46:41 +08:00
|
|
|
* @mixin \Illuminate\Database\Eloquent\Builder
|
2017-12-13 06:58:27 +08:00
|
|
|
* @mixin \Illuminate\Notifications\Notifiable
|
2017-12-16 02:36:13 +08:00
|
|
|
* @mixin \Laratrust\Traits\LaratrustUserTrait
|
2017-06-09 02:28:26 +08:00
|
|
|
*/
|
|
|
|
class User extends Authenticatable
|
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
use HasFactory;
|
|
|
|
use HasRelationships;
|
2018-03-02 06:20:13 +08:00
|
|
|
use JournalTrait;
|
2017-12-16 02:36:13 +08:00
|
|
|
use LaratrustUserTrait;
|
2018-03-02 06:20:13 +08:00
|
|
|
use Notifiable;
|
2017-06-09 02:28:26 +08:00
|
|
|
|
2017-12-13 06:58:27 +08:00
|
|
|
public $table = 'users';
|
|
|
|
|
2018-03-06 09:55:48 +08:00
|
|
|
/**
|
|
|
|
* The journal type for when it's being created
|
|
|
|
*/
|
|
|
|
public $journal_type = JournalType::USER;
|
|
|
|
|
2017-12-13 06:58:27 +08:00
|
|
|
protected $fillable = [
|
2019-07-17 01:54:14 +08:00
|
|
|
'id',
|
2017-12-13 06:58:27 +08:00
|
|
|
'name',
|
|
|
|
'email',
|
|
|
|
'password',
|
2019-07-17 01:54:14 +08:00
|
|
|
'pilot_id',
|
2017-12-13 06:58:27 +08:00
|
|
|
'airline_id',
|
2018-01-04 05:41:21 +08:00
|
|
|
'rank_id',
|
2021-06-04 22:51:59 +08:00
|
|
|
'discord_id',
|
2021-06-05 04:57:27 +08:00
|
|
|
'discord_private_channel_id',
|
2017-12-31 02:15:26 +08:00
|
|
|
'api_key',
|
2018-01-10 09:08:16 +08:00
|
|
|
'country',
|
2017-12-13 06:58:27 +08:00
|
|
|
'home_airport_id',
|
|
|
|
'curr_airport_id',
|
2017-12-26 05:19:34 +08:00
|
|
|
'last_pirep_id',
|
2018-01-04 05:41:21 +08:00
|
|
|
'flights',
|
|
|
|
'flight_time',
|
2018-09-05 08:09:33 +08:00
|
|
|
'transfer_time',
|
2018-04-02 19:47:31 +08:00
|
|
|
'avatar',
|
2017-12-13 06:58:27 +08:00
|
|
|
'timezone',
|
2017-12-23 02:46:46 +08:00
|
|
|
'state',
|
|
|
|
'status',
|
2018-09-21 00:14:18 +08:00
|
|
|
'toc_accepted',
|
2018-05-25 11:17:41 +08:00
|
|
|
'opt_in',
|
2021-06-05 01:20:33 +08:00
|
|
|
'last_ip',
|
2022-02-12 04:58:16 +08:00
|
|
|
'notes',
|
2018-01-30 08:14:55 +08:00
|
|
|
'created_at',
|
|
|
|
'updated_at',
|
2017-12-13 06:58:27 +08:00
|
|
|
];
|
2017-06-09 02:28:26 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The attributes that should be hidden for arrays.
|
|
|
|
*/
|
2017-12-13 02:43:58 +08:00
|
|
|
protected $hidden = [
|
2018-01-31 02:31:59 +08:00
|
|
|
'api_key',
|
2022-02-05 03:17:07 +08:00
|
|
|
'email',
|
|
|
|
'name',
|
2021-06-04 22:51:59 +08:00
|
|
|
'discord_id',
|
2022-02-05 03:17:07 +08:00
|
|
|
'discord_private_channel_id',
|
2017-12-13 02:43:58 +08:00
|
|
|
'password',
|
2021-06-05 01:20:33 +08:00
|
|
|
'last_ip',
|
2017-12-13 02:43:58 +08:00
|
|
|
'remember_token',
|
2022-02-12 04:58:16 +08:00
|
|
|
'notes',
|
2017-12-13 02:43:58 +08:00
|
|
|
];
|
2017-07-04 14:05:37 +08:00
|
|
|
|
2017-12-13 02:43:58 +08:00
|
|
|
protected $casts = [
|
2019-07-17 01:54:14 +08:00
|
|
|
'id' => 'integer',
|
|
|
|
'pilot_id' => 'integer',
|
2018-09-05 09:27:16 +08:00
|
|
|
'flights' => 'integer',
|
|
|
|
'flight_time' => 'integer',
|
|
|
|
'transfer_time' => 'integer',
|
|
|
|
'balance' => 'double',
|
|
|
|
'state' => 'integer',
|
|
|
|
'status' => 'integer',
|
2018-09-21 00:14:18 +08:00
|
|
|
'toc_accepted' => 'boolean',
|
2018-09-05 09:27:16 +08:00
|
|
|
'opt_in' => 'boolean',
|
2017-12-13 02:43:58 +08:00
|
|
|
];
|
2017-06-29 08:56:10 +08:00
|
|
|
|
2017-12-23 06:32:21 +08:00
|
|
|
public static $rules = [
|
2019-07-17 21:48:20 +08:00
|
|
|
'name' => 'required',
|
|
|
|
'email' => 'required|email',
|
2019-07-17 23:00:30 +08:00
|
|
|
'pilot_id' => 'required|integer',
|
2017-12-23 06:32:21 +08:00
|
|
|
];
|
|
|
|
|
2018-01-01 03:08:41 +08:00
|
|
|
/**
|
2022-03-14 23:45:18 +08:00
|
|
|
* Format the pilot ID/ident
|
2020-04-07 00:03:19 +08:00
|
|
|
*
|
2022-03-14 23:45:18 +08:00
|
|
|
* @return Attribute
|
2020-04-07 00:03:19 +08:00
|
|
|
*/
|
2022-03-14 23:45:18 +08:00
|
|
|
public function ident(): Attribute
|
2020-04-07 00:03:19 +08:00
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
return Attribute::make(
|
|
|
|
get: function ($_, $attrs) {
|
|
|
|
$length = setting('pilots.id_length');
|
|
|
|
$ident_code = filled(setting('pilots.id_code')) ? setting(
|
|
|
|
'pilots.id_code'
|
|
|
|
) : optional($this->airline)->icao;
|
|
|
|
|
|
|
|
return $ident_code.str_pad($attrs['pilot_id'], $length, '0', STR_PAD_LEFT);
|
|
|
|
}
|
|
|
|
);
|
2020-04-07 00:03:19 +08:00
|
|
|
}
|
|
|
|
|
2018-02-07 00:33:39 +08:00
|
|
|
/**
|
2022-03-14 23:45:18 +08:00
|
|
|
* Return a "privatized" version of someones name - First and middle names full, last name initials
|
2018-08-27 00:40:04 +08:00
|
|
|
*
|
2022-03-14 23:45:18 +08:00
|
|
|
* @return Attribute
|
2018-02-07 00:33:39 +08:00
|
|
|
*/
|
2022-03-14 23:45:18 +08:00
|
|
|
public function namePrivate(): Attribute
|
2018-02-07 00:33:39 +08:00
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
return Attribute::make(
|
|
|
|
get: function ($_, $attrs) {
|
|
|
|
$name_parts = explode(' ', $attrs['name']);
|
|
|
|
$count = count($name_parts);
|
|
|
|
if ($count === 1) {
|
|
|
|
return $name_parts[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
$gdpr_name = '';
|
|
|
|
$last_name = $name_parts[$count - 1];
|
|
|
|
$loop_count = 0;
|
|
|
|
|
|
|
|
while ($loop_count < ($count - 1)) {
|
|
|
|
$gdpr_name .= $name_parts[$loop_count].' ';
|
|
|
|
$loop_count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
$gdpr_name .= mb_substr($last_name, 0, 1);
|
|
|
|
|
|
|
|
return mb_convert_case($gdpr_name, MB_CASE_TITLE);
|
|
|
|
}
|
|
|
|
);
|
2018-02-07 00:33:39 +08:00
|
|
|
}
|
|
|
|
|
2018-02-07 01:02:40 +08:00
|
|
|
/**
|
2022-03-14 23:45:18 +08:00
|
|
|
* Shortcut for timezone
|
2018-08-27 00:40:04 +08:00
|
|
|
*
|
2022-03-14 23:45:18 +08:00
|
|
|
* @return Attribute
|
2018-02-07 01:02:40 +08:00
|
|
|
*/
|
2022-03-14 23:45:18 +08:00
|
|
|
public function tz(): Attribute
|
2018-02-07 01:02:40 +08:00
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
return Attribute::make(
|
|
|
|
get: fn ($_, $attrs) => $attrs['timezone'],
|
|
|
|
set: fn ($value) => [
|
|
|
|
'timezone' => $value,
|
|
|
|
]
|
|
|
|
);
|
2018-02-07 01:02:40 +08:00
|
|
|
}
|
2018-05-25 11:17:41 +08:00
|
|
|
|
2018-05-01 23:28:47 +08:00
|
|
|
/**
|
2018-08-27 00:40:04 +08:00
|
|
|
* Return a File model
|
|
|
|
*/
|
2022-03-14 23:45:18 +08:00
|
|
|
public function avatar(): Attribute
|
2018-05-01 23:28:47 +08:00
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
return Attribute::make(
|
|
|
|
get: function ($_, $attrs) {
|
|
|
|
if (!$attrs['avatar']) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return new File([
|
|
|
|
'path' => $attrs['avatar'],
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
);
|
2018-05-01 23:28:47 +08:00
|
|
|
}
|
2018-02-07 01:02:40 +08:00
|
|
|
|
2018-01-01 03:08:41 +08:00
|
|
|
/**
|
2018-01-20 06:07:31 +08:00
|
|
|
* @param mixed $size Size of the gravatar, in pixels
|
2018-08-27 00:40:04 +08:00
|
|
|
*
|
2018-01-01 03:08:41 +08:00
|
|
|
* @return string
|
|
|
|
*/
|
2018-03-20 09:50:40 +08:00
|
|
|
public function gravatar($size = null)
|
2017-08-12 01:06:17 +08:00
|
|
|
{
|
2018-01-08 23:22:12 +08:00
|
|
|
$default = config('gravatar.default');
|
2018-01-20 06:07:31 +08:00
|
|
|
|
2021-12-01 03:36:17 +08:00
|
|
|
$uri = config('gravatar.url').md5(strtolower(trim($this->email))).'?d='.urlencode($default);
|
2018-01-20 06:07:31 +08:00
|
|
|
|
2018-03-20 09:50:40 +08:00
|
|
|
if ($size !== null) {
|
2018-01-20 06:07:31 +08:00
|
|
|
$uri .= '&s='.$size;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $uri;
|
2017-08-12 01:06:17 +08:00
|
|
|
}
|
|
|
|
|
2020-03-30 01:33:14 +08:00
|
|
|
public function resolveAvatarUrl()
|
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
/** @var File $avatar */
|
|
|
|
$avatar = $this->avatar;
|
2020-03-30 01:33:14 +08:00
|
|
|
if (empty($avatar)) {
|
|
|
|
return $this->gravatar();
|
|
|
|
}
|
2022-03-14 23:45:18 +08:00
|
|
|
|
2020-03-30 03:05:56 +08:00
|
|
|
return $avatar->url;
|
2020-03-30 01:33:14 +08:00
|
|
|
}
|
|
|
|
|
2017-06-29 08:56:10 +08:00
|
|
|
/**
|
|
|
|
* Foreign Keys
|
|
|
|
*/
|
|
|
|
public function airline()
|
|
|
|
{
|
2018-01-08 23:22:12 +08:00
|
|
|
return $this->belongsTo(Airline::class, 'airline_id');
|
2017-06-29 08:56:10 +08:00
|
|
|
}
|
|
|
|
|
2020-10-12 04:06:09 +08:00
|
|
|
/**
|
|
|
|
* @return \App\Models\Award[]|mixed
|
|
|
|
*/
|
2018-03-17 13:18:03 +08:00
|
|
|
public function awards()
|
|
|
|
{
|
2020-10-12 04:06:09 +08:00
|
|
|
return $this->belongsToMany(Award::class, 'user_awards');
|
2018-03-17 13:18:03 +08:00
|
|
|
}
|
|
|
|
|
2020-08-12 05:48:51 +08:00
|
|
|
/**
|
|
|
|
* The bid rows
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
|
|
*/
|
|
|
|
public function bids()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Bid::class, 'user_id');
|
|
|
|
}
|
|
|
|
|
2017-06-29 08:56:10 +08:00
|
|
|
public function home_airport()
|
|
|
|
{
|
2018-01-08 23:22:12 +08:00
|
|
|
return $this->belongsTo(Airport::class, 'home_airport_id');
|
2017-06-29 08:56:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public function current_airport()
|
|
|
|
{
|
2018-01-08 23:22:12 +08:00
|
|
|
return $this->belongsTo(Airport::class, 'curr_airport_id');
|
2017-06-29 08:56:10 +08:00
|
|
|
}
|
|
|
|
|
2017-12-26 05:19:34 +08:00
|
|
|
public function last_pirep()
|
|
|
|
{
|
2018-01-08 23:22:12 +08:00
|
|
|
return $this->belongsTo(Pirep::class, 'last_pirep_id');
|
2017-12-26 05:19:34 +08:00
|
|
|
}
|
|
|
|
|
2020-08-12 05:48:51 +08:00
|
|
|
public function fields()
|
2017-08-04 10:02:02 +08:00
|
|
|
{
|
2020-08-12 05:48:51 +08:00
|
|
|
return $this->hasMany(UserFieldValue::class, 'user_id');
|
2017-08-04 10:02:02 +08:00
|
|
|
}
|
|
|
|
|
2017-06-30 04:50:16 +08:00
|
|
|
public function pireps()
|
|
|
|
{
|
2021-05-05 21:56:28 +08:00
|
|
|
return $this->hasMany(Pirep::class, 'user_id');
|
2017-06-30 04:50:16 +08:00
|
|
|
}
|
|
|
|
|
2017-06-29 08:56:10 +08:00
|
|
|
public function rank()
|
|
|
|
{
|
2018-01-08 23:22:12 +08:00
|
|
|
return $this->belongsTo(Rank::class, 'rank_id');
|
2017-06-29 08:56:10 +08:00
|
|
|
}
|
2021-12-01 03:36:17 +08:00
|
|
|
|
|
|
|
public function typeratings()
|
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
return $this->belongsToMany(
|
|
|
|
Typerating::class,
|
|
|
|
'typerating_user',
|
|
|
|
'user_id',
|
|
|
|
'typerating_id'
|
|
|
|
);
|
2021-12-01 03:36:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public function rated_subfleets()
|
|
|
|
{
|
2022-03-14 23:45:18 +08:00
|
|
|
return $this->hasManyDeep(
|
|
|
|
Subfleet::class,
|
|
|
|
['typerating_user', Typerating::class, 'typerating_subfleet']
|
|
|
|
);
|
2021-12-01 03:36:17 +08:00
|
|
|
}
|
2017-06-09 02:28:26 +08:00
|
|
|
}
|