The objects. * @psalm-return T[] */ public function findAll(); /** * Finds objects by a set of criteria. * * Optionally sorting and limiting details can be passed. An implementation may throw * an UnexpectedValueException if certain values of the sorting or limiting details are * not supported. * * @param array $criteria * @param string[]|null $orderBy * @param int|null $limit * @param int|null $offset * @psalm-param array|null $orderBy * * @return object[] The objects. * @psalm-return T[] * * @throws UnexpectedValueException */ public function findBy(array $criteria, ?array $orderBy = null, $limit = null, $offset = null); /** * Finds a single object by a set of criteria. * * @param array $criteria The criteria. * * @return object|null The object. * @psalm-return T|null */ public function findOneBy(array $criteria); /** * Returns the class name of the object managed by the repository. * * @return string * @psalm-return class-string */ public function getClassName(); }