Source code for langchain_community.agent_toolkits.ainetwork.toolkit

from __future__ import annotations

from typing import TYPE_CHECKING, List, Literal, Optional

from langchain_core.pydantic_v1 import root_validator

from langchain_community.agent_toolkits.base import BaseToolkit
from langchain_community.tools import BaseTool
from langchain_community.tools.ainetwork.app import AINAppOps
from langchain_community.tools.ainetwork.owner import AINOwnerOps
from langchain_community.tools.ainetwork.rule import AINRuleOps
from langchain_community.tools.ainetwork.transfer import AINTransfer
from langchain_community.tools.ainetwork.utils import authenticate
from langchain_community.tools.ainetwork.value import AINValueOps

if TYPE_CHECKING:
    from ain.ain import Ain


[docs]class AINetworkToolkit(BaseToolkit): """Toolkit for interacting with AINetwork Blockchain. *Security Note*: This toolkit contains tools that can read and modify the state of a service; e.g., by reading, creating, updating, deleting data associated with this service. See https://python.langchain.com/docs/security for more information. """ network: Optional[Literal["mainnet", "testnet"]] = "testnet" interface: Optional[Ain] = None @root_validator(pre=True) def set_interface(cls, values: dict) -> dict: if not values.get("interface"): values["interface"] = authenticate(network=values.get("network", "testnet")) return values class Config: """Pydantic config.""" validate_all = True arbitrary_types_allowed = True
[docs] def get_tools(self) -> List[BaseTool]: """Get the tools in the toolkit.""" return [ AINAppOps(), AINOwnerOps(), AINRuleOps(), AINTransfer(), AINValueOps(), ]