mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-06 03:02:34 +01:00
b3eb2ae3b4
* Working on subscriptions * Implement return type in models * Subscription implementation * Improvements to handling importation of large accountS * Loggin imports * Activate collector * Improve memory usage of import script * Appen Tags into emails - fix companygatewaytransformer
121 lines
3.1 KiB
PHP
121 lines
3.1 KiB
PHP
<?php
|
|
/**
|
|
* Invoice Ninja (https://invoiceninja.com)
|
|
*
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
*
|
|
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
|
|
*
|
|
* @license https://opensource.org/licenses/AAL
|
|
*/
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Relations\Pivot;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
class CompanyUser extends Pivot
|
|
{
|
|
use \Staudenmeir\EloquentHasManyDeep\HasRelationships;
|
|
use SoftDeletes;
|
|
|
|
// protected $guarded = ['id'];
|
|
|
|
protected $dateFormat = 'Y-m-d H:i:s.u';
|
|
|
|
/**
|
|
* The attributes that should be cast to native types.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $casts = [
|
|
'updated_at' => 'timestamp',
|
|
'created_at' => 'timestamp',
|
|
'deleted_at' => 'timestamp',
|
|
'settings' => 'object',
|
|
'notifications' => 'object',
|
|
'permissions' => 'string',
|
|
];
|
|
|
|
protected $fillable = [
|
|
'account_id',
|
|
'permissions',
|
|
'notifications',
|
|
'settings',
|
|
'is_admin',
|
|
'is_owner',
|
|
'is_locked',
|
|
'slack_webhook_url',
|
|
];
|
|
|
|
public function getEntityType()
|
|
{
|
|
return CompanyUser::class;
|
|
}
|
|
|
|
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', 'slack_webhook_url', 'migrating');
|
|
}
|
|
|
|
public function company_pivot()
|
|
{
|
|
return $this->hasOne(Company::class)->withPivot('permissions', 'settings', 'is_admin', 'is_owner', 'is_locked', 'slack_webhook_url', 'migrating');
|
|
}
|
|
|
|
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');
|
|
}
|
|
|
|
|
|
public function scopeAuthCompany($query)
|
|
{
|
|
$query->where('company_id', auth()->user()->companyId());
|
|
|
|
return $query;
|
|
}
|
|
}
|