'timestamp', 'created_at' => 'timestamp', 'deleted_at' => 'timestamp', 'settings' => 'object', ]; protected $fillable = [ 'account_id', 'permissions', 'notifications', 'settings', 'is_admin', 'is_owner', 'is_locked' ]; public function account() { return $this->belongsTo(Account::class); } public function user_pivot() { return $this->hasOne(User::class)->withPivot('permissions', 'settings', 'is_admin', 'is_owner', 'is_locked'); } public function company_pivot() { return $this->hasOne(Company::class)->withPivot('permissions', 'settings', 'is_admin', 'is_owner', 'is_locked'); } public function user() { return $this->belongsTo(User::class); } public function company() { return $this->belongsTo(Company::class); } public function users() { return $this->hasMany(User::class); } /*todo monitor this function - may fail under certain conditions*/ public function token() { return $this->hasMany(CompanyToken::class, 'user_id', 'user_id'); //return $this->hasMany(CompanyToken::class); //return $this->hasOne(CompanyToken::class, 'user_id', 'user_id','company_id', 'company_id'); //return $this->hasOneDeep(CompanyToken::class, [CompanyUser::class], ['user_id','company_id'], ['company_id','company_id']); //return $this->belongsTo(CompanyToken::class, 'user_id', 'user_id'); // return $this->hasOneThrough( // CompanyToken::class, // CompanyUser::class, // 'user_id', // Foreign key on CompanyUser table... // 'company_id', // Foreign key on CompanyToken table... // 'user_id', // Local key on CompanyToken table... // 'company_id' // Local key on CompanyUser table... // ); } public function tokens() { return $this->hasMany(CompanyToken::class, 'user_id', 'user_id'); } }