HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/qas.sports-crowd.com/app/User.php
<?php

namespace App;

use Laravel\Passport\HasApiTokens;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Database\Eloquent\SoftDeletes;
use Schedula\Laravel\PassportSocialite\User\UserSocialAccount;
use Illuminate\Auth\Notifications\ResetPassword;
use Illuminate\Notifications\Messages\MailMessage;
use App\Rol;
use App\UserInformation;
use App\Order;
use App\Mailbox;
use App\Message;
use App\Chat;
use App\Address;
use App\DocumentType;
use App\Models\Dependent;
use App\Models\Membership\MembershipSubscriber;
// use Spatie\Activitylog\Traits\LogsActivity;

class User extends Authenticatable implements UserSocialAccount
{
    use HasApiTokens, Notifiable, SoftDeletes;
    protected $dates = ['deleted_at'];

    // use LogsActivity;
    // protected static $logAttributes = ['*'];
    // protected static $logOnlyDirty = true;
    // protected static $logName = 'users';

    public function rol()
    {
        return $this->belongsTo(Rol::class)->select(array('id', 'name', 'route'));
    }

    public function userInfo()
    {
        return $this->hasOne(UserInformation::class);
    }

    public function orders()
    {
        return $this->hasMany(Order::class);
    }

    public function mailboxes()
    {
        return $this->hasMany(Mailbox::class);
    }

    public function messages()
    {
        return $this->hasMany(Message::class);
    }

    public function chats()
    {
        return $this->hasOne(Chat::class);
    }

    public function addresses()
    {
        return $this->hasMany(Address::class)->with('coverage');
    }

    public function documentType()
    {
        return $this->belongsTo(DocumentType::class)->select(array('id', 'name', 'alias'));
    }

    public function academy_schedules_coaches()
    {
        return $this->hasMany(AcademySchedulesCoach::class);
    }

    public function user_tags()
    {
        return $this->hasMany(UserTag::class)->select(array('tag_id', 'user_id'))->with('tag');
    }

    public function tags()
    {
        return $this->belongsToMany(Tag::class, 'user_tags')->withTimestamps();
    }

    public function memberships()
    {
        return $this->hasMany(MembershipSubscriber::class)->with('membership')->whereIn('status', ['CONFIRMED', 'EXPIRED'])->orderBy('id', 'desc');
    }

    public function getShortNameAttribute()
    {
        return explode(' ', trim($this->first_name))[0] . ' ' . explode(' ', trim($this->last_name))[0];
    }

    public function dependents()
    {
        return $this->hasMany(Dependent::class, 'guardian_user_id');
    }

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'name',
        'email',
        'password',
        'dial_code',
        'country_code',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password',
        'remember_token',
    ];

    /**
     * Find user using social provider's id
     *
     * @param string $provider Provider name as requested from oauth e.g. facebook
     * @param string $id User id of social provider
     *
     * @return User
     */
    public static function findForPassportSocialite($provider, $id)
    {
        $account = UserInformation::where('social_provider', $provider)->where('social_id', $id)->first();
        $userAccount = User::find($account->user_id);

        if ($userAccount) {
            return $userAccount;
        }
        return;
    }


    /**
     * Sends the password reset notification.
     *
     * @param  string $token
     *
     * @return void
     */
    public function sendPasswordResetNotification($token)
    {
        $this->notify(new CustomPassword($token));
    }
}

class CustomPassword extends ResetPassword
{
    public function toMail($notifiable)
    {
        $corporateIdentity = CorporateIdentity::first();
        return (new MailMessage)
            ->from('noreply@sports-crowd.com', 'Sports Crowd')
            ->subject('Restablecer contraseƱa ' . config('mail.from.name'))
            ->view('mails.user.password_reset', [
                'token' => $this->token,
                'corporateIdentity' => $corporateIdentity,
                'user' => $notifiable,
            ]);
    }
}