The primary way for using guardrails in your project is:
- Create a
RailsConfig
object. - Create an
LLMRails
instance which provides an interface to the LLM that automatically applies the configured guardrails. - Generate LLM responses using the
LLMRails.generate(...)
orLLMRails.generate_async(...)
methods.
from nemoguardrails import LLMRails, RailsConfig
config = RailsConfig.from_path("path/to/config")
app = LLMRails(config)
new_message = app.generate(messages=[{
"role": "user",
"content": "Hello! What can you do for me?"
}])
The RailsConfig
class contains the key bits of information for configuring guardrails:
models
: The list of models used by the rails configuration.user_messages
: The list of user messages that should be used for the rails.bot_messages
: The list of bot messages that should be used for the rails.flows
: The list of flows that should be used for the rails.instructions
: List of instructions in natural language (currently, only general instruction is supported).docs
: List of documents included in the knowledge base.sample_conversation
: The sample conversation to be used inside the prompts.actions_server_url
: The actions server to be used. If specified, the actions will be executed through the actions server.
To use a guardrails configuration, you can call the LLMRails.generate
or LLMRails.generate_async
methods.
The LLMRails.generate
method takes as input either a prompt
or a messages
array. When a prompt is provided, the guardrails apply as in a single-turn conversation. The structure of a message is the following:
properties:
role:
type: "string"
enum: ["user", "assistant", "context"]
content:
oneOf:
- type: "string"
- type: "object"
An example of conversation history is the following:
[
{
"role": "user",
"content": "Hello!"
},
{
"role": "assistant",
"content": "Hello! How can I help you?"
},
{
"role": "user",
"content": "I want to know if my insurance covers certain expenses."
}
]
An example which also sets the initial context is the following:
[
{
"role": "context",
"content": {
"user_name": "John",
"access_level": "admin"
}
},
{
"role": "user",
"content": "Hello!"
},
{
"role": "assistant",
"content": "Hello! How can I help you?"
},
{
"role": "user",
"content": "I want to know if my insurance covers certain expenses."
}
]
Actions are a key component of the Guardrails toolkit. Actions enable the execution of python code inside guardrails.
The following are the default actions included in the toolkit:
Core actions:
generate_user_intent
: Generate the canonical form for what the user said.generate_next_step
: Generates the next step in the current conversation flow.generate_bot_message
: Generate a bot message based on the desired bot intent.retrieve_relevant_chunks
: Retrieves the relevant chunks from the knowledge base and adds them to the context.
Guardrail-specific actions:
self_check_facts
: Check the facts for the last bot response w.r.t. the extracted relevant chunks from the knowledge base.self_check_input
: Check if the user input should be allowed.self_check_output
: Check if the bot response should be allowed.self_check_hallucination
: Check if the last bot response is a hallucination.
For convenience, this toolkit also includes a selection of LangChain tools, wrapped as actions:
apify
: Apify is a web scraping and web automation platform that enables you to build your own web crawlers and web scrapers.bing_search
: Wrapper around the Bing Web Search API.google_search
: Wrapper around the Google Search API from Langchain.searx_search
: Wrapper around the Searx API. Alternative to Google/Bing Search.google_serper
: Wrapper around the SerpApi Google Search API. It can be used to add answer boxes and knowledge graphs from Google Search.openweather_query
: Wrapper around OpenWeatherMap's API for retrieving weather information.serp_api_query
: Wrapper around the SerpAPI API. It provides access to search engines and helps answer questions about current events.wikipedia_query
: A wrapper around the Wikipedia API. It uses the MediaWiki API to retrieve information from Wikipedia.wolfram_alpha_query
: A wrapper around the Wolfram Alpha API. It can be used to answer math and science questions.zapier_nla_query
: Wrapper around the Zapier NLA API. It provides access to over 5k applications and 20k actions to automate your workflows.
You can register a Langchain chain as an action using the LLMRails.register_action method:
app.register_action(some_chain, name="some_chain")
When a chain is invoked as an action, the parameters of the action correspond to the input keys of the chain. For the return value, if the output of the chain has a single key, the value will be returned. If the chain has multiple output keys, the dictionary of output keys and their values is returned. See the LangChain Integration Guide for more details.
You can register any python function as a custom action, using the action
decorator or with LLMRails(RailsConfig).register_action(action: callable, name: Optional[str])
.
from nemoguardrails.actions import action
@action()
async def some_action():
# Do some work
return "some_result"
By default, the name of the action is set to the name of the function. However, you can change it by specifying a different name.
from nemoguardrails.actions import action
@action(name="some_action_name")
async def some_action():
# Do some work
return "some_result"
Actions can take any number of parameters. Since actions are invoked from Colang flows, the parameters' type is limited to string, integer, float, boolean, list and dictionary.
The following parameters are special and are provided automatically by the NeMo Guardrails toolkit, if they appear in the signature of an action:
events
: the history of events so far; the last one is the one triggering the action itself;context
: the context data available to the action;llm
: access to the LLM instance (BaseLLM from LangChain);config
: the fullRailsConfig
instance.
These parameters are only meant to be used in advanced use cases.
The following are the parameters that can be used in the actions:
Parameters | Description | Type | Example |
---|---|---|---|
events |
The history of events so far; the last one is the one triggering the action itself. | List[dict] | [ {'type': 'UtteranceUserActionFinished', ...}, {'type': 'StartInternalSystemAction', 'action_name': 'generate_user_intent', ...}, {'type': 'InternalSystemActionFinished', 'action_name': 'generate_user_intent', ...} ] |
context |
The context data available to the action. | dict | { 'last_user_message': ..., 'last_bot_message': ..., 'retrieved_relevant_chunks': ... } |
llm |
Access to the LLM instance (BaseLLM from LangChain). | BaseLLM | OpenAI(model="gpt-3.5-turbo-instruct",...) |