. */ namespace SP\Domain\Account\Ports; use SP\Domain\Account\Models\PublicLink; use SP\Domain\Common\Ports\Repository; use SP\Domain\Core\Dtos\ItemSearchDto; use SP\Domain\Core\Exceptions\ConstraintException; use SP\Domain\Core\Exceptions\QueryException; use SP\Domain\Core\Exceptions\SPException; use SP\Infrastructure\Common\Repositories\DuplicatedItemException; use SP\Infrastructure\Database\QueryResult; /** * Class PublicLinkRepository * * @package SP\Infrastructure\Common\Repositories\PublicLink */ interface PublicLinkRepository extends Repository { /** * Deletes an item * * @param int $id * * @return void * @throws ConstraintException * @throws QueryException */ public function delete(int $id): void; /** * Returns all the items * * @return QueryResult */ public function getAll(): QueryResult; /** * Deletes all the items for given ids * * @param array $ids * * @return int * @throws ConstraintException * @throws QueryException */ public function deleteByIdBatch(array $ids): int; /** * Searches for items by a given filter * * @param ItemSearchDto $itemSearchData * * @return QueryResult */ public function search(ItemSearchDto $itemSearchData): QueryResult; /** * Creates an item * * @param PublicLink $publicLinkData * * @return QueryResult * @throws DuplicatedItemException * @throws QueryException * @throws ConstraintException */ public function create(PublicLink $publicLinkData): QueryResult; /** * Incrementar el contador de visitas de un enlace * * @param PublicLink $publicLinkData * * @return bool * @throws ConstraintException * @throws QueryException */ public function addLinkView(PublicLink $publicLinkData): bool; /** * Updates an item * * @param PublicLink $publicLinkData * * @return bool * @throws ConstraintException * @throws QueryException */ public function update(PublicLink $publicLinkData): bool; /** * Refreshes a public link * * @param PublicLink $publicLinkData * * @return bool * @throws SPException * @throws ConstraintException * @throws QueryException */ public function refresh(PublicLink $publicLinkData): bool; /** * Returns the item for given id * * @param int $id * * @return QueryResult */ public function getById(int $id): QueryResult; /** * @param $hash string * * @return QueryResult */ public function getByHash(string $hash): QueryResult; /** * Devolver el hash asociado a un elemento * * @param int $itemId * * @return QueryResult */ public function getHashForItem(int $itemId): QueryResult; }