diff --git a/semantic_router/index/base.py b/semantic_router/index/base.py index c99dd53e20ea387ecfc247d9661e6fd71b4ad5f2..63db675201ad292b74437e7d8567042926a27629 100644 --- a/semantic_router/index/base.py +++ b/semantic_router/index/base.py @@ -86,7 +86,7 @@ class BaseIndex(BaseModel): if self.index is None: logger.warning("Index is None, could not retrieve utterances.") return [] - _, metadata = self._get_all(include_metadata=True) + _, metadata = self._get_all(include_metadata=True) # include_metadata required route_tuples = parse_route_info(metadata=metadata) if not include_metadata: # we remove the metadata from the tuples (ie only keep 0, 1 items) diff --git a/semantic_router/index/hybrid_local.py b/semantic_router/index/hybrid_local.py index f35be7cd352e965382565878eddb53a4ef990df0..704df2575e114dfa3aabe0fb802860a3820bfdae 100644 --- a/semantic_router/index/hybrid_local.py +++ b/semantic_router/index/hybrid_local.py @@ -61,13 +61,12 @@ class HybridLocalIndex(LocalIndex): """Gets a list of route and utterance objects currently stored in the index. :param include_metadata: Whether to include function schemas and metadata in - the returned Utterance objects - HybridLocalIndex only supports False. + the returned Utterance objects - HybridLocalIndex doesn't include metadata so + this parameter is ignored. :type include_metadata: bool :return: A list of Utterance objects. :rtype: List[Utterance] """ - if include_metadata: - raise ValueError("include_metadata is not supported for HybridLocalIndex.") if self.routes is None or self.utterances is None: return [] return [Utterance.from_tuple(x) for x in zip(self.routes, self.utterances)] diff --git a/semantic_router/index/local.py b/semantic_router/index/local.py index a3bf3d9d355b71249894c3dbf045f069cc4bfe22..9cccfc4ade9a84e520f95eac42de90ffa87922c9 100644 --- a/semantic_router/index/local.py +++ b/semantic_router/index/local.py @@ -68,13 +68,11 @@ class LocalIndex(BaseIndex): """Gets a list of route and utterance objects currently stored in the index. :param include_metadata: Whether to include function schemas and metadata in - the returned Utterance objects - HybridLocalIndex only supports False. - :type include_metadata: bool + the returned Utterance objects - LocalIndex doesn't include metadata so this + parameter is ignored. :return: A list of Utterance objects. :rtype: List[Utterance] """ - if include_metadata: - raise ValueError("include_metadata is not supported for HybridLocalIndex.") if self.routes is None or self.utterances is None: return [] return [Utterance.from_tuple(x) for x in zip(self.routes, self.utterances)] diff --git a/semantic_router/index/qdrant.py b/semantic_router/index/qdrant.py index 10095d56bdec059f8c4d3f078123ed0094ce3587..42ef48c0111b260d0d9a238a6b105da76806ce04 100644 --- a/semantic_router/index/qdrant.py +++ b/semantic_router/index/qdrant.py @@ -192,17 +192,13 @@ class QdrantIndex(BaseIndex): """Gets a list of route and utterance objects currently stored in the index. :param include_metadata: Whether to include function schemas and metadata in - the returned Utterance objects - QdrantIndex only supports False. + the returned Utterance objects - QdrantIndex does not currently support this + parameter so it is ignored. If required for your use-case please reach out to + semantic-router maintainers on GitHub via an issue or PR. :type include_metadata: bool :return: A list of Utterance objects. :rtype: List[Utterance] """ - if include_metadata: - raise NotImplementedError( - "include_metadata is not supported for QdrantIndex. If required please " - "reach out to maintainers on GitHub via an issue or PR." - ) - # Check if collection exists first if not self.client.collection_exists(self.index_name): return []