77 lines
2.2 KiB
PHP
77 lines
2.2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @file classes/userGroup/relationships/UserUserGroup.php
|
|
*
|
|
* Copyright (c) 2014-2021 Simon Fraser University
|
|
* Copyright (c) 2000-2021 John Willinsky
|
|
* Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
|
|
*
|
|
* @class \PKP\userGroup\relationships\UserUserGroup
|
|
*
|
|
* @brief UserUserGroup metadata class.
|
|
*/
|
|
|
|
namespace PKP\userGroup\relationships;
|
|
|
|
use APP\facades\Repo;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
use Illuminate\Database\Eloquent\Casts\Attribute;
|
|
|
|
class UserUserGroup extends \Illuminate\Database\Eloquent\Model
|
|
{
|
|
public $timestamps = false;
|
|
public $incrementing = false;
|
|
protected $primaryKey = null;
|
|
protected $fillable = ['userGroupId', 'userId'];
|
|
|
|
public function user(): Attribute
|
|
{
|
|
return Attribute::make(
|
|
get: fn ($value, $attributes) => Repo::user()->get($attributes['user_id']),
|
|
set: fn ($value) => $value->getId()
|
|
);
|
|
}
|
|
|
|
public function userGroup(): Attribute
|
|
{
|
|
return Attribute::make(
|
|
get: fn ($value, $attributes) => Repo::userGroup()->get($attributes['user_group_id']),
|
|
set: fn ($value) => $value->getId()
|
|
);
|
|
}
|
|
|
|
public function userId(): Attribute
|
|
{
|
|
return Attribute::make(
|
|
get: fn ($user, $attributes) => $attributes['user_id'],
|
|
set: fn ($value) => ['user_id' => $value]
|
|
);
|
|
}
|
|
|
|
public function userGroupId(): Attribute
|
|
{
|
|
return Attribute::make(
|
|
get: fn ($userGroup, $attributes) => $attributes['user_group_id'],
|
|
set: fn ($value) => ['user_group_id' => $value]
|
|
);
|
|
}
|
|
|
|
public function scopeWithUserId(Builder $query, int $userId): Builder
|
|
{
|
|
return $query->where('user_user_groups.user_id', $userId);
|
|
}
|
|
|
|
public function scopeWithUserGroupId(Builder $query, int $userGroupId): Builder
|
|
{
|
|
return $query->where('user_user_groups.user_group_id', $userGroupId);
|
|
}
|
|
|
|
public function scopeWithContextId(Builder $query, int $contextId): Builder
|
|
{
|
|
return $query
|
|
->join('user_groups as ug', 'user_user_groups.user_group_id', '=', 'ug.user_group_id')
|
|
->where('ug.context_id', $contextId);
|
|
}
|
|
}
|