mirror of
https://github.com/hwchase17/langchain.git
synced 2025-09-03 12:07:36 +00:00
community[major], core[patch], langchain[patch], experimental[patch]: Create langchain-community (#14463)
Moved the following modules to new package langchain-community in a backwards compatible fashion: ``` mv langchain/langchain/adapters community/langchain_community mv langchain/langchain/callbacks community/langchain_community/callbacks mv langchain/langchain/chat_loaders community/langchain_community mv langchain/langchain/chat_models community/langchain_community mv langchain/langchain/document_loaders community/langchain_community mv langchain/langchain/docstore community/langchain_community mv langchain/langchain/document_transformers community/langchain_community mv langchain/langchain/embeddings community/langchain_community mv langchain/langchain/graphs community/langchain_community mv langchain/langchain/llms community/langchain_community mv langchain/langchain/memory/chat_message_histories community/langchain_community mv langchain/langchain/retrievers community/langchain_community mv langchain/langchain/storage community/langchain_community mv langchain/langchain/tools community/langchain_community mv langchain/langchain/utilities community/langchain_community mv langchain/langchain/vectorstores community/langchain_community mv langchain/langchain/agents/agent_toolkits community/langchain_community mv langchain/langchain/cache.py community/langchain_community mv langchain/langchain/adapters community/langchain_community mv langchain/langchain/callbacks community/langchain_community/callbacks mv langchain/langchain/chat_loaders community/langchain_community mv langchain/langchain/chat_models community/langchain_community mv langchain/langchain/document_loaders community/langchain_community mv langchain/langchain/docstore community/langchain_community mv langchain/langchain/document_transformers community/langchain_community mv langchain/langchain/embeddings community/langchain_community mv langchain/langchain/graphs community/langchain_community mv langchain/langchain/llms community/langchain_community mv langchain/langchain/memory/chat_message_histories community/langchain_community mv langchain/langchain/retrievers community/langchain_community mv langchain/langchain/storage community/langchain_community mv langchain/langchain/tools community/langchain_community mv langchain/langchain/utilities community/langchain_community mv langchain/langchain/vectorstores community/langchain_community mv langchain/langchain/agents/agent_toolkits community/langchain_community mv langchain/langchain/cache.py community/langchain_community ``` Moved the following to core ``` mv langchain/langchain/utils/json_schema.py core/langchain_core/utils mv langchain/langchain/utils/html.py core/langchain_core/utils mv langchain/langchain/utils/strings.py core/langchain_core/utils cat langchain/langchain/utils/env.py >> core/langchain_core/utils/env.py rm langchain/langchain/utils/env.py ``` See .scripts/community_split/script_integrations.sh for all changes
This commit is contained in:
51
libs/community/langchain_community/utilities/nasa.py
Normal file
51
libs/community/langchain_community/utilities/nasa.py
Normal file
@@ -0,0 +1,51 @@
|
||||
"""Util that calls several NASA APIs."""
|
||||
import json
|
||||
|
||||
import requests
|
||||
from langchain_core.pydantic_v1 import BaseModel
|
||||
|
||||
IMAGE_AND_VIDEO_LIBRARY_URL = "https://images-api.nasa.gov"
|
||||
|
||||
|
||||
class NasaAPIWrapper(BaseModel):
|
||||
def get_media(self, query: str) -> str:
|
||||
params = json.loads(query)
|
||||
if params.get("q"):
|
||||
queryText = params["q"]
|
||||
params.pop("q")
|
||||
else:
|
||||
queryText = ""
|
||||
response = requests.get(
|
||||
IMAGE_AND_VIDEO_LIBRARY_URL + "/search?q=" + queryText, params=params
|
||||
)
|
||||
data = response.json()
|
||||
return data
|
||||
|
||||
def get_media_metadata_manifest(self, query: str) -> str:
|
||||
response = requests.get(IMAGE_AND_VIDEO_LIBRARY_URL + "/asset/" + query)
|
||||
return response.json()
|
||||
|
||||
def get_media_metadata_location(self, query: str) -> str:
|
||||
response = requests.get(IMAGE_AND_VIDEO_LIBRARY_URL + "/metadata/" + query)
|
||||
return response.json()
|
||||
|
||||
def get_video_captions_location(self, query: str) -> str:
|
||||
response = requests.get(IMAGE_AND_VIDEO_LIBRARY_URL + "/captions/" + query)
|
||||
return response.json()
|
||||
|
||||
def run(self, mode: str, query: str) -> str:
|
||||
if mode == "search_media":
|
||||
output = self.get_media(query)
|
||||
elif mode == "get_media_metadata_manifest":
|
||||
output = self.get_media_metadata_manifest(query)
|
||||
elif mode == "get_media_metadata_location":
|
||||
output = self.get_media_metadata_location(query)
|
||||
elif mode == "get_video_captions_location":
|
||||
output = self.get_video_captions_location(query)
|
||||
else:
|
||||
output = f"ModeError: Got unexpected mode {mode}."
|
||||
|
||||
try:
|
||||
return json.dumps(output)
|
||||
except Exception:
|
||||
return str(output)
|
Reference in New Issue
Block a user