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
|
|
|
|
from typing import Any
|
|
|
|
|
|
|
|
_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())
|