. */ namespace SP\Domain\Security\In; use SP\Core\Exceptions\ConstraintException; use SP\Core\Exceptions\QueryException; use SP\DataModel\ItemSearchData; use SP\Infrastructure\Database\QueryResult; use SP\Infrastructure\Security\Repositories\TrackRequest; /** * Class TrackRepository * * @package SP\Infrastructure\Security\Repositories */ interface TrackRepositoryInterface { /** * @param TrackRequest $trackRequest * * @return int * @throws ConstraintException * @throws QueryException */ public function add(TrackRequest $trackRequest): int; /** * @param $id int * * @return int * @throws QueryException * @throws ConstraintException */ public function delete(int $id): int; /** * @param $id int * * @return int * @throws QueryException * @throws ConstraintException */ public function unlock(int $id): int; /** * Clears tracks * * @return bool con el resultado * @throws QueryException * @throws ConstraintException */ public function clear(): bool; /** * @param $id int * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function getById(int $id): QueryResult; /** * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function getAll(): QueryResult; /** * Devuelve los tracks de un cliente desde un tiempo y origen determinados * * @param TrackRequest $trackRequest * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function getTracksForClientFromTime(TrackRequest $trackRequest): QueryResult; /** * Searches for items by a given filter * * @param ItemSearchData $itemSearchData * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function search(ItemSearchData $itemSearchData): QueryResult; }