mirror of
https://github.com/hwchase17/langchain.git
synced 2025-05-31 12:09:58 +00:00
Upgrade to using a literal for specifying the extra which is the recommended approach in pydantic 2. This works correctly also in pydantic v1. ```python from pydantic.v1 import BaseModel class Foo(BaseModel, extra="forbid"): x: int Foo(x=5, y=1) ``` And ```python from pydantic.v1 import BaseModel class Foo(BaseModel): x: int class Config: extra = "forbid" Foo(x=5, y=1) ``` ## Enum -> literal using grit pattern: ``` engine marzano(0.1) language python or { `extra=Extra.allow` => `extra="allow"`, `extra=Extra.forbid` => `extra="forbid"`, `extra=Extra.ignore` => `extra="ignore"` } ``` Resorted attributes in config and removed doc-string in case we will need to deal with going back and forth between pydantic v1 and v2 during the 0.3 release. (This will reduce merge conflicts.) ## Sort attributes in Config: ``` engine marzano(0.1) language python function sort($values) js { return $values.text.split(',').sort().join("\n"); } class_definition($name, $body) as $C where { $name <: `Config`, $body <: block($statements), $values = [], $statements <: some bubble($values) assignment() as $A where { $values += $A }, $body => sort($values), } ```
66 lines
1.8 KiB
Python
66 lines
1.8 KiB
Python
"""Util that calls Golden."""
|
|
|
|
import json
|
|
from typing import Dict, Optional
|
|
|
|
import requests
|
|
from langchain_core.pydantic_v1 import BaseModel, root_validator
|
|
from langchain_core.utils import get_from_dict_or_env
|
|
|
|
GOLDEN_BASE_URL = "https://golden.com"
|
|
GOLDEN_TIMEOUT = 5000
|
|
|
|
|
|
class GoldenQueryAPIWrapper(BaseModel):
|
|
"""Wrapper for Golden.
|
|
|
|
Docs for using:
|
|
|
|
1. Go to https://golden.com and sign up for an account
|
|
2. Get your API Key from https://golden.com/settings/api
|
|
3. Save your API Key into GOLDEN_API_KEY env variable
|
|
|
|
"""
|
|
|
|
golden_api_key: Optional[str] = None
|
|
|
|
class Config:
|
|
extra = "forbid"
|
|
|
|
@root_validator(pre=True)
|
|
def validate_environment(cls, values: Dict) -> Dict:
|
|
"""Validate that api key and python package exists in environment."""
|
|
golden_api_key = get_from_dict_or_env(
|
|
values, "golden_api_key", "GOLDEN_API_KEY"
|
|
)
|
|
values["golden_api_key"] = golden_api_key
|
|
|
|
return values
|
|
|
|
def run(self, query: str) -> str:
|
|
"""Run query through Golden Query API and return the JSON raw result."""
|
|
|
|
headers = {"apikey": self.golden_api_key or ""}
|
|
|
|
response = requests.post(
|
|
f"{GOLDEN_BASE_URL}/api/v2/public/queries/",
|
|
json={"prompt": query},
|
|
headers=headers,
|
|
timeout=GOLDEN_TIMEOUT,
|
|
)
|
|
if response.status_code != 201:
|
|
return response.text
|
|
|
|
content = json.loads(response.content)
|
|
query_id = content["id"]
|
|
|
|
response = requests.get(
|
|
(
|
|
f"{GOLDEN_BASE_URL}/api/v2/public/queries/{query_id}/results/"
|
|
"?pageSize=10"
|
|
),
|
|
headers=headers,
|
|
timeout=GOLDEN_TIMEOUT,
|
|
)
|
|
return response.text
|