. */ namespace Poniverse\Ponyfm\Models; use Gravatar; use Illuminate\Auth\Authenticatable; use Illuminate\Auth\Passwords\CanResetPassword; use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract; use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract; use Illuminate\Database\Eloquent\Model; use Illuminate\Foundation\Auth\Access\Authorizable; use Auth; use Illuminate\Support\Str; use Venturecraft\Revisionable\RevisionableTrait; /** * Poniverse\Ponyfm\Models\User * * @property integer $id * @property string $display_name * @property string $username * @property boolean $sync_names * @property string $email * @property string $gravatar * @property string $slug * @property boolean $uses_gravatar * @property boolean $can_see_explicit_content * @property string $bio * @property integer $track_count * @property integer $comment_count * @property \Carbon\Carbon $created_at * @property \Carbon\Carbon $updated_at * @property integer $avatar_id * @property string $remember_token * @property boolean $is_archived * @property \Carbon\Carbon $disabled_at * @property-read \Poniverse\Ponyfm\Models\Image $avatar * @property-read \Illuminate\Database\Eloquent\Collection|\Poniverse\Ponyfm\Models\ResourceUser[] $users * @property-read \Illuminate\Database\Eloquent\Collection|\Poniverse\Ponyfm\Models\Role[] $roles * @property-read \Illuminate\Database\Eloquent\Collection|\Poniverse\Ponyfm\Models\Comment[] $comments * @property-read \Illuminate\Database\Eloquent\Collection|\Poniverse\Ponyfm\Models\Track[] $tracks * @property-read mixed $url * @property-read mixed $message_url * @property-read \Illuminate\Database\Eloquent\Collection|\Venturecraft\Revisionable\Revision[] $revisionHistory * @method static \Illuminate\Database\Query\Builder|\Poniverse\Ponyfm\Models\User userDetails() */ class User extends Model implements AuthenticatableContract, CanResetPasswordContract, \Illuminate\Contracts\Auth\Access\Authorizable { use Authenticatable, CanResetPassword, Authorizable, RevisionableTrait; protected $table = 'users'; protected $casts = [ 'id' => 'integer', 'sync_names' => 'boolean', 'uses_gravatar' => 'boolean', 'can_see_explicit_content' => 'boolean', 'track_count' => 'integer', 'comment_count' => 'integer', 'avatar_id' => 'integer', 'is_archived' => 'boolean', ]; protected $dates = ['created_at', 'updated_at', 'disabled_at']; protected $hidden = ['disabled_at']; public function scopeUserDetails($query) { if (Auth::check()) { $query->with([ 'users' => function ($query) { $query->whereUserId(Auth::user()->id); } ]); } return !$query; } /** * @param string $username * @param string $displayName * @param string $email * @return User */ public static function findOrCreate(string $username, string $displayName, string $email) { $user = static::where('username', $username) ->where('is_archived', false) ->first(); if (null !== $user) { return $user; } else { $user = new User; $user->username = $username; $user->display_name = $displayName; $user->email = $email; $user->uses_gravatar = true; $user->save(); return $user; } } public function avatar() { return $this->belongsTo('Poniverse\Ponyfm\Models\Image'); } public function users() { return $this->hasMany('Poniverse\Ponyfm\Models\ResourceUser', 'artist_id'); } public function roles() { return $this->belongsToMany(Role::class, 'role_user'); } public function comments() { return $this->hasMany('Poniverse\Ponyfm\Models\Comment', 'profile_id')->orderBy('created_at', 'desc'); } public function tracks() { return $this->hasMany('Poniverse\Ponyfm\Models\Track', 'user_id'); } public function getIsArchivedAttribute() { return (bool)$this->attributes['is_archived']; } public function getUrlAttribute() { return action('ArtistsController@getProfile', $this->slug); } public function getMessageUrlAttribute() { return 'http://mlpforums.com/index.php?app=members&module=messaging§ion=send&do=form&fromMemberID=' . $this->id; } public function getAuthIdentifier() { return $this->getKey(); } public function getAuthPassword() { return $this->password_hash; } public function getReminderEmail() { return $this->email; } public function setDisplayNameAttribute($value) { $this->attributes['display_name'] = $value; $this->attributes['slug'] = Str::slug($value); } public function getAvatarUrl($type = Image::NORMAL) { if (!$this->uses_gravatar) { return $this->avatar->getUrl($type); } if ($this->email == "redacted@example.net") { return Gravatar::getUrl($this->id . "", Image::$ImageTypes[$type]['width'], "identicon"); } $email = $this->gravatar; if (!strlen($email)) { $email = $this->email; } return Gravatar::getUrl($email, Image::$ImageTypes[$type]['width']); } /** * Get the token value for the "remember me" session. * * @return string */ public function getRememberToken() { return $this->remember_token; } /** * Set the token value for the "remember me" session. * * @param string $value * @return void */ public function setRememberToken($value) { $this->remember_token = $value; } /** * Get the column name for the "remember me" token. * * @return string */ public function getRememberTokenName() { return "remember_token"; } /** * Returns true if this user has the given role. * * @param $roleName * @return bool */ public function hasRole($roleName) { foreach ($this->roles as $role) { if ($role->name === $roleName) { return true; } } return false; } }