2024-02-22 00:18:36 +00:00
|
|
|
"""**Storage** is an implementation of key-value store.
|
2023-12-11 21:53:30 +00:00
|
|
|
|
2024-02-22 00:18:36 +00:00
|
|
|
Storage module provides implementations of various key-value stores that conform
|
2023-12-11 21:53:30 +00:00
|
|
|
to a simple key-value interface.
|
|
|
|
|
2024-02-22 00:18:36 +00:00
|
|
|
The primary goal of these storages is to support caching.
|
|
|
|
|
|
|
|
|
|
|
|
**Class hierarchy:**
|
|
|
|
|
|
|
|
.. code-block::
|
|
|
|
|
|
|
|
BaseStore --> <name>Store # Examples: MongoDBStore, RedisStore
|
|
|
|
|
|
|
|
""" # noqa: E501
|
2023-12-11 21:53:30 +00:00
|
|
|
|
2024-03-12 22:18:54 +00:00
|
|
|
import importlib
|
2024-04-10 17:01:19 +00:00
|
|
|
from typing import TYPE_CHECKING, Any
|
|
|
|
|
|
|
|
if TYPE_CHECKING:
|
|
|
|
from langchain_community.storage.astradb import (
|
|
|
|
AstraDBByteStore, # noqa: F401
|
|
|
|
AstraDBStore, # noqa: F401
|
|
|
|
)
|
|
|
|
from langchain_community.storage.mongodb import (
|
|
|
|
MongoDBStore, # noqa: F401
|
|
|
|
)
|
|
|
|
from langchain_community.storage.redis import (
|
|
|
|
RedisStore, # noqa: F401
|
|
|
|
)
|
|
|
|
from langchain_community.storage.upstash_redis import (
|
|
|
|
UpstashRedisByteStore, # noqa: F401
|
|
|
|
UpstashRedisStore, # noqa: F401
|
|
|
|
)
|
|
|
|
|
|
|
|
__all__ = [
|
|
|
|
"AstraDBByteStore",
|
|
|
|
"AstraDBStore",
|
|
|
|
"MongoDBStore",
|
|
|
|
"RedisStore",
|
|
|
|
"UpstashRedisByteStore",
|
|
|
|
"UpstashRedisStore",
|
|
|
|
]
|
2024-03-12 22:18:54 +00:00
|
|
|
|
|
|
|
_module_lookup = {
|
|
|
|
"AstraDBByteStore": "langchain_community.storage.astradb",
|
|
|
|
"AstraDBStore": "langchain_community.storage.astradb",
|
|
|
|
"MongoDBStore": "langchain_community.storage.mongodb",
|
|
|
|
"RedisStore": "langchain_community.storage.redis",
|
|
|
|
"UpstashRedisByteStore": "langchain_community.storage.upstash_redis",
|
|
|
|
"UpstashRedisStore": "langchain_community.storage.upstash_redis",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
def __getattr__(name: str) -> Any:
|
|
|
|
if name in _module_lookup:
|
|
|
|
module = importlib.import_module(_module_lookup[name])
|
|
|
|
return getattr(module, name)
|
|
|
|
raise AttributeError(f"module {__name__} has no attribute {name}")
|
|
|
|
|
|
|
|
|
|
|
|
__all__ = list(_module_lookup.keys())
|