aboutsummaryrefslogtreecommitdiff
path: root/.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py
diff options
context:
space:
mode:
authorS. Solomon Darnell2025-03-28 21:52:21 -0500
committerS. Solomon Darnell2025-03-28 21:52:21 -0500
commit4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch)
treeee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-master.tar.gz
two version of R2R are hereHEADmaster
Diffstat (limited to '.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py')
-rw-r--r--.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py b/.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py
new file mode 100644
index 00000000..429634b7
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/litellm/caching/llm_caching_handler.py
@@ -0,0 +1,40 @@
+"""
+Add the event loop to the cache key, to prevent event loop closed errors.
+"""
+
+import asyncio
+
+from .in_memory_cache import InMemoryCache
+
+
+class LLMClientCache(InMemoryCache):
+
+ def update_cache_key_with_event_loop(self, key):
+ """
+ Add the event loop to the cache key, to prevent event loop closed errors.
+ If none, use the key as is.
+ """
+ try:
+ event_loop = asyncio.get_event_loop()
+ stringified_event_loop = str(id(event_loop))
+ return f"{key}-{stringified_event_loop}"
+ except Exception: # handle no current event loop
+ return key
+
+ def set_cache(self, key, value, **kwargs):
+ key = self.update_cache_key_with_event_loop(key)
+ return super().set_cache(key, value, **kwargs)
+
+ async def async_set_cache(self, key, value, **kwargs):
+ key = self.update_cache_key_with_event_loop(key)
+ return await super().async_set_cache(key, value, **kwargs)
+
+ def get_cache(self, key, **kwargs):
+ key = self.update_cache_key_with_event_loop(key)
+
+ return super().get_cache(key, **kwargs)
+
+ async def async_get_cache(self, key, **kwargs):
+ key = self.update_cache_key_with_event_loop(key)
+
+ return await super().async_get_cache(key, **kwargs)