From 2382e6b2a1bf969622b2c9de75ee60e138b7cbb8 Mon Sep 17 00:00:00 2001 From: Chester Curme Date: Thu, 12 Sep 2024 10:28:48 -0400 Subject: [PATCH] fix async client init for aiohttp 3.10+ --- .../pinecone/langchain_pinecone/embeddings.py | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/libs/partners/pinecone/langchain_pinecone/embeddings.py b/libs/partners/pinecone/langchain_pinecone/embeddings.py index 2dc964ed562b8..42b18d2ab9065 100644 --- a/libs/partners/pinecone/langchain_pinecone/embeddings.py +++ b/libs/partners/pinecone/langchain_pinecone/embeddings.py @@ -1,3 +1,4 @@ +import asyncio import logging from typing import Any, Dict, Iterable, List, Optional @@ -85,6 +86,15 @@ def set_default_config(cls, values: dict) -> Any: values[key] = value return values + async def _init_async_client(self, api_key: str) -> None: + self._async_client = aiohttp.ClientSession( + headers={ + "Api-Key": api_key, + "Content-Type": "application/json", + "X-Pinecone-API-Version": "2024-07", + } + ) + @model_validator(mode="after") def validate_environment(self) -> Self: """Validate that Pinecone version and credentials exist in environment.""" @@ -94,13 +104,8 @@ def validate_environment(self) -> Self: # initialize async client if not self._async_client: - self._async_client = aiohttp.ClientSession( - headers={ - "Api-Key": api_key_str, - "Content-Type": "application/json", - "X-Pinecone-API-Version": "2024-07", - } - ) + asyncio.run(self._init_async_client(api_key_str)) + return self def _get_batch_iterator(self, texts: List[str]) -> Iterable: