mirror of
https://github.com/hwchase17/langchain.git
synced 2025-06-22 23:00:00 +00:00
Refactor: use SecretStr for Predibase llms (#15119)
This commit is contained in:
parent
0a9a73a9c9
commit
1abcf441ae
@ -2,7 +2,7 @@ from typing import Any, Dict, List, Mapping, Optional
|
|||||||
|
|
||||||
from langchain_core.callbacks import CallbackManagerForLLMRun
|
from langchain_core.callbacks import CallbackManagerForLLMRun
|
||||||
from langchain_core.language_models.llms import LLM
|
from langchain_core.language_models.llms import LLM
|
||||||
from langchain_core.pydantic_v1 import Field
|
from langchain_core.pydantic_v1 import Field, SecretStr
|
||||||
|
|
||||||
|
|
||||||
class Predibase(LLM):
|
class Predibase(LLM):
|
||||||
@ -13,7 +13,7 @@ class Predibase(LLM):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
model: str
|
model: str
|
||||||
predibase_api_key: str
|
predibase_api_key: SecretStr
|
||||||
model_kwargs: Dict[str, Any] = Field(default_factory=dict)
|
model_kwargs: Dict[str, Any] = Field(default_factory=dict)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -30,7 +30,7 @@ class Predibase(LLM):
|
|||||||
try:
|
try:
|
||||||
from predibase import PredibaseClient
|
from predibase import PredibaseClient
|
||||||
|
|
||||||
pc = PredibaseClient(token=self.predibase_api_key)
|
pc = PredibaseClient(token=self.predibase_api_key.get_secret_value())
|
||||||
except ImportError as e:
|
except ImportError as e:
|
||||||
raise ImportError(
|
raise ImportError(
|
||||||
"Could not import Predibase Python package. "
|
"Could not import Predibase Python package. "
|
||||||
|
@ -0,0 +1,19 @@
|
|||||||
|
from langchain_core.pydantic_v1 import SecretStr
|
||||||
|
from pytest import CaptureFixture
|
||||||
|
|
||||||
|
from langchain_community.llms.predibase import Predibase
|
||||||
|
|
||||||
|
|
||||||
|
def test_api_key_is_string() -> None:
|
||||||
|
llm = Predibase(predibase_api_key="secret-api-key")
|
||||||
|
assert isinstance(llm.predibase_api_key, SecretStr)
|
||||||
|
|
||||||
|
|
||||||
|
def test_api_key_masked_when_passed_via_constructor(
|
||||||
|
capsys: CaptureFixture,
|
||||||
|
) -> None:
|
||||||
|
llm = Predibase(predibase_api_key="secret-api-key")
|
||||||
|
print(llm.predibase_api_key, end="")
|
||||||
|
captured = capsys.readouterr()
|
||||||
|
|
||||||
|
assert captured.out == "**********"
|
Loading…
Reference in New Issue
Block a user