'timestamp', 'created_at' => 'timestamp', 'deleted_at' => 'timestamp', 'settings' => 'object', ]; protected $fillable = [ 'account_id', 'permissions', '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->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... ); */ } }