. */ namespace SP\Domain\User\Ports; use SP\Domain\Core\Exceptions\ConstraintException; use SP\Domain\Core\Exceptions\QueryException; use SP\Domain\User\Models\UserToUserGroup as UserToUserGroupModel; use SP\Infrastructure\Database\QueryResult; /** * Class UserToUserGroupRepository * * @template T of UserToUserGroupModel */ interface UserToUserGroupRepository { /** * Checks whether the user is included in the group * * @param int $groupId * @param int $userId * * @return bool */ public function checkUserInGroup(int $groupId, int $userId): bool; /** * Returns the groups which the user belongs to * * @param int $userId * * @return QueryResult */ public function getGroupsForUser(int $userId): QueryResult; /** * Updates users from a group * * @param int $id * @param array $users * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function update(int $id, array $users): QueryResult; /** * Deletes users from a group * * @param $id int * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function delete(int $id): QueryResult; /** * Adds users to a group * * @param int $groupId * @param array $users * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function add(int $groupId, array $users): QueryResult; /** * Returns users from a group by group id * * @param $id int * * @return QueryResult */ public function getById(int $id): QueryResult; }