. */ namespace SP\Domain\User\Ports; use SP\Domain\Common\Services\ServiceException; use SP\Domain\Core\Dtos\ItemSearchDto; use SP\Domain\Core\Exceptions\ConstraintException; use SP\Domain\Core\Exceptions\QueryException; use SP\Domain\User\Models\UserGroup as UserGroupModel; use SP\Infrastructure\Common\Repositories\NoSuchItemException; use SP\Infrastructure\Database\QueryResult; /** * Class UserGroupService * * @template T of UserGroupModel */ interface UserGroupService { /** * @throws ConstraintException * @throws QueryException */ public function search(ItemSearchDto $itemSearchData): QueryResult; /** * @throws ConstraintException * @throws QueryException * @throws NoSuchItemException */ public function getById(int $id): UserGroupModel; /** * @throws ConstraintException * @throws QueryException * @throws NoSuchItemException */ public function delete(int $id): void; /** * @param int[] $ids * * @throws ServiceException * @throws ConstraintException * @throws QueryException */ public function deleteByIdBatch(array $ids): int; /** * @throws ServiceException */ public function create(UserGroupModel $userGroup): int; /** * @throws ServiceException */ public function update(UserGroupModel $userGroup): void; /** * Get all items from the service's repository * * @return UserGroupModel[] * @throws ConstraintException * @throws QueryException */ public function getAll(): array; /** * Returns the item for given name * * @throws NoSuchItemException * @throws ConstraintException * @throws QueryException */ public function getByName(string $name): UserGroupModel; /** * Returns the users that are using the given group id * * @throws ConstraintException * @throws QueryException */ public function getUsage(int $id): array; /** * Returns the items that are using the given group id * * @throws ConstraintException * @throws QueryException */ public function getUsageByUsers(int $id): array; }