'timestamp', 'updated_at' => 'timestamp', 'created_at' => 'timestamp', 'deleted_at' => 'timestamp', 'settings' => 'object', 'notifications' => 'object', 'permissions' => 'string', ]; protected $fillable = [ 'account_id', 'permissions', 'notifications', 'settings', 'react_settings', 'is_admin', 'is_owner', 'is_locked', 'slack_webhook_url', 'shop_restricted', ]; protected $touches = ['user']; protected $with = ['user', 'account']; public function getEntityType() { return self::class; } // public function tax_rates() // { // return $this->hasMany(TaxRate::class, 'company_id', 'company_id'); // } public function account() { return $this->belongsTo(Account::class); } public function user_pivot() { return $this->hasOne(User::class)->withPivot('permissions', 'settings', 'react_settings', 'is_admin', 'is_owner', 'is_locked', 'slack_webhook_url', 'migrating'); } public function company_pivot() { return $this->hasOne(Company::class)->withPivot('permissions', 'settings', 'react_settings', 'is_admin', 'is_owner', 'is_locked', 'slack_webhook_url', 'migrating'); } public function user() { return $this->belongsTo(User::class)->withTrashed(); } public function company() { return $this->belongsTo(Company::class); } public function users() { return $this->hasMany(User::class)->withTrashed(); } /*todo monitor this function - may fail under certain conditions*/ public function token() { return $this->hasMany(CompanyToken::class, 'user_id', 'user_id'); } public function tokens() { return $this->hasMany(CompanyToken::class, 'user_id', 'user_id'); } public function scopeAuthCompany($query) { $query->where('company_id', auth()->user()->companyId()); return $query; } }