Conditions in Flows
Conditions are logical statements in flows to determine which flows can be executed, to navigate branches of your logic, and to validate slot values.
Conditions
Conditions are used in flows in three different places:
- In flow guards to determine whether a flow can be started.
- In the next field of a flow step to choose between branches of your business logic.
- In the
rejections
field of acollect
step to validate slot values.
Syntax
Conditions in flows are written using natural language that can include logical operators, conditional operators and other constructs. They are evaluated with the pypred library.
These conditions support the following operators,
not
: Negates a condition.and
: Combines two conditions with logical AND.or
: Combines two conditions with logical OR.>
: Greater than.>=
: Greater than or equal to.<
: Less than.<=
: Less than or equal to.=
: Equal to.!=
: Not equal to.is
: Checks for identity.is not
: Checks for non-identity.contains
: Subset operator that checks if a set contains a valuematches
: Uses regular expressions to match strings.
Parentheses
Use parentheses to group expressions and control the order of evaluation. For example:
Subset Operator
Subset operator contains
can be used in the format SET contains VALUE
where SET
is the set of possible values and VALUE
being the name of slot.
For example:
contains
operator can also be used to identify substrings when used as
slots.product contains "Rasa"
however this check is case-sensitive.
Constants
- String literals: Enclose in single or double quotes (
'example'
or"example"
). - Numeric literals: Numbers without quotes (
42
). - Constants:
true
,false
,undefined
,null
,empty
Regular Expressions
When using the matches
operator, you can include regular expression modifiers.
The regex modifier should be enclosed in quotes. For example, this flow step checks if
the zipcode
slot contains a United States zip code :
A case-insensitive substring comparison can be made with the condition
product matches "(?i).*rasa.*"
which checks for the substring rasa
within
the variable product
.
Empty Values
If you want to check if a boolean slot is not set, you need to use the syntax <boolean-slot> is null
.
To check if a text slot is not set or empty, use the syntax not <text-slot>
.
Examples
Here are some examples of conditions that demonstrate the use of different constructs.
Namespaces
Namespaces are used to access different types of data in predicates used in
branching conditions, slot validation,
and flow guards.
There are two available namespaces: slots
and context
. The slots
namespace
is used to access slot values, while the context
namespace is used to access
the current dialogue frame properties.
Slots
The slots
namespace is used to access slot values. The slot name must be
prefixed with slots.
to be accessible in the condition. For example:
Make sure to have the slot defined in the domain.
If the slot is not defined in the domain or the slot is not prefixed with slots.
namespace,
the validation that runs during training will fail with an appropriate error.
Context
The context
namespace is used to access the properties of the current dialogue frame.
The property must be prefixed with context.
to be accessible in
the predicate. For example:
You can also use jinja templating to access the context namespace. For example:
Dialogue Frames
The dialogue manager organizes the advancement of flows (both user defined and built-in) in a dialogue frame stack. The dialogue frame stack represents a LIFO (Last-In-First-Out) stack of dialogue frames. Different types of dialogue frames are mapped to built-in conversational patterns that enable conversation repair.
Each dialogue frame has a flow_id
and step_id
property. The flow_id
is the id of the current
flow and the step_id
is the id of the current step in the flow.
The following dialogue frames types are available:
- cancel: handles flow cancellation
- chitchat: handles chitchat
- clarify: handles clarification
- collect information: handles information collection
- completion: handles flow completion
- continue interrupted: handles continuation of interrupted flows
- correction: handles correction
- internal error: handles internal errors
- search: handles knowledge search
- skip question: handles skipping of information collection
- code change: cleans the stack after an assistant update
- can not handle: handles situations where the assistant cannot handle
- human handoff: handles handoff to human
Cancel
The flow_id
is pattern_cancel_flow
. The step_id
is START
.
In addition, the following properties are available:
canceled_name
: the name of the flow that should be canceledcanceled_frames
: the list of stack frames that should be canceled
Chitchat
The flow_id
is pattern_chitchat
. The step_id
is START
.
Clarify
The flow_id
is pattern_clarify
. The step_id
is START
.
In addition, the following properties are available:
names
: the list of names of the flows that the user can choose fromclarification_options
: the options that the user can choose from as a string
Collect Information
The flow_id
is pattern_collect_information
. The step_id
is START
.
In addition, the following properties are available:
collect
: the name of the slot that should be filledutter
: the response that should be executed to ask the user for informationcollect_action
: the action that should be executed to ask the user for informationrejections
: the optional list of validation checks that should be executed if the user provides invalid information
Note that if you are using the context.collect
property in your flow, you must write this in jinja templating style
and prefix it with the slots.
namespace. This is because context.collect
corresponds to the slot name, and every slot must
be preceded by the slots.
namespace.
For example:
Completion
The flow_id
is pattern_completed
. The step_id
is START
.
In addition, the following properties are available:
previous_flow_name
: the name of the flow that has been completed
Continue Interrupted
The flow_id
is pattern_continue_interrupted
. The step_id
is START
.
In addition, the following properties are available:
previous_flow_name
: the name of the flow that was interrupted
Correction
The flow_id
is pattern_correction
. The step_id
is START
.
In addition, the following properties are available:
is_reset_only
: indicates if the correction is only a reset of the flowcorrected_slots
: slot key-value pairs that should be correctedreset_flow_id
: the ID of the flow to reset to, defaults toNone
reset_step_id
: the ID of the step to reset to, defaults toNone
Internal Error
The flow_id
is pattern_internal_error
. The step_id
is START
.
In addition, the following properties are available:
error_type
: string indicates the type of errorinfo
: additional info to be provided to the user
Knowledge Search
The flow_id
is pattern_search
. The step_id
is START
.
Skip Question
The flow_id
is pattern_skip_question
. The step_id
is START
.
Code Change
The flow_id
is pattern_code_change
. The step_id
is START
.
Can Not Handle
The flow_id
is pattern_cannot_handle
. The step_id
is START
.
In addition, the following properties are available:
reason
: string indicates the reason why the assistant cannot handle
Human Handoff
The flow_id
is pattern_human_handoff
. The step_id
is START
.