Atomic State
AtomicState
An atomic state is a state executing real tasks, which usually are small functional modules, such as LLM module and TTS module.
In an agent on MyShell, an entered atomic state usually means a sent message with buttons if specified.
AtomicState
id
string (Optional)
Globally unique identifier.
"1234_5678_9101"
type
"state" (Optional)
Specifies that this is an atomic state.
"state"
properties
Object (Optional)
Static config. Similar to metadata.
properties.is_final
boolean (Optional)
Flag to check if the current state is final. Default to false.
true
properties.cache
boolean (Optional)
Flag to enable cache mode. When set to true, the state will run only once and store the result. Default to false.
inputs
Object (Optional)
Expected inputs, including user inputs and other states' outputs.
inputs.[input_name]
Input or Expression (Required)
Specification about each input.
{"type" : "IM", "user_input": true}
tasks
SupportModule[] (Optional)
Tasks executed in written order, involving no control ability such as if/else and loop. Each element is configuration for supported modules, including LLMModule, LLMFunctionModule and TtsModule for now.
outputs
Object (Optional)
Output values, including state's outputs and modification to parent automata's context, if it has a parent automata.
outputs.[output_name]
Variable or Expression (Required)
Usually its an expression evaluating an intermediate variable.
{"context.prompt" : "{{reply}}"}
render
RenderConfig (Optional)
Controls how to display the result to the user.
{"text": "{{reply}}", "buttons": ["context": "Chat", "on_click": "start_chat"]}
transitions
Object (Optional)
Indicates how state flows responding to user action. transitions's keys are events which the state will handle, including events triggered by itself or its children states if its children states don't handle this event. We treat both actual happened events and user intents as events.
AtomicState can trigger special events, including CHAT, ALWAYS
transitions[event]
Transition (Required)
It could simply a target state name, or a TransitionCase object.
{"start_chat" : {"target": "chat_page"}}
Example:
Inputs
Each Input
signifies that a variable is required for the state to function, and it is typically provided by user input. If there is user input whose type is not "IM"
, then a transition to this state would prompt the opening of a modal, allowing the user to complete the input form.
The primary distinction between Input
and Output
in this context is that Input
generally includes additional fields that govern how the user should complete the input form. These fields could include things like data validation rules, default values, or specific instructions for the user, which provide guidance on the expected form and content of the input. Output
, in contrast, typically refers to the information that is conveyed back to the user after processing their input or completing a particular state transition.
Input
type
"text" | "image" | "audio" | ”IM" (Required)
The type of a given variable. "IM" refers to input that originates from the user's bot Instant Messaging interface.
"text"
value
string (Optional)
The value of a given variable. The type of the value depends on the type field. For text, value could be any string. For image, audio, value is string of URL. ForIM, value is usually undefined. If the transition to the state specifies target_inputs, value won’t be overridden.
default_value
string (Optional)
The default value of an input variable, which is used when no value is given. The type is same as value. If the transition to the state specifies target_inputs, default_value will be overridden.
"{{prompt}}"
user_input
Boolean (Optional)
An optional flag that indicates whether the input should come from the user. Defaults to false.
true
name
string (Optional)
An optional string that serves as a label for the form input.
"username"
description
string (Optional)
An optional string that serves as a description for the form input.
"Input your username here."
choices
string[] (Optional)
Allow users to select the value from given choices.
["GPT", "Gemini"]
validations
Validation[] (Optional)
Allow users to specify how this input should be validated. The validators are processed one by one. The first failed validation will produce corresponding error message.
If not specified, it is equivalent to set to [{"required": true}]
[{"required": false}, {"max_length": 100}]
Validation
required
boolean (Optional)
Defaults to true
. If set to false
, the input is optional.
max_length
number (Optional)
The character limitation for a text
input.
Defaults to 1500.
max_file_size
number (Optional)
The file size (in bytes) limitation for file-type inputs including image
, audio
, video
and file
.
10 * 1024 * 1024
max_number
number (Optional)
The max number for number and integer inputs.
1500
min_number
number (Optional)
The min number for number and integer inputs.
-1
error_message
string (Optional)
(Coming soon) The error message the user would see when validation fails.
Tasks
We support LLM module, LLM Function module and TTS module for now. More kinds of modules and customized modules are coming very soon.
To fully understand the configuration of these modules, you should refer to the Modules section where detailed information about each module, including their inputs, outputs, and functionality, is provided.
Important Update: In previous versions, we supported the Object
type for defining tasks
. Please be aware that the execution order cannot be guaranteed for the Object
type and it will become deprecated in a future release. It is recommended to transition to using the Array
type to ensure the execution order of tasks
.
Outputs
Currently, the use of context is necessary to store any output variables, as they are fundamentally kept within the parent automata's scope. However, in a few days, we will introduce support for isolated output variables that can be accessed through a prefix tied to the state name.
Variable
is a subset of Input
, only including type
and value
fields.
Variable
type
"text"
"image"
"audio"
value
string (Optional)
The value of a given variable. The type of the value depends on the type field. For text, value could be any string. For image, audio, value is string of URL. ForIM, value is usually undefined. For expression, value is Expression.
Render
RenderConfig
is responsible for defining how a bot presents the results executed by a state to the user. It can specify content of the result, whether it's a text message, an audio message, or interactive buttons that facilitate transitions to different states or prompt further user interaction.
RenderConfig
text
string (Optional)
The text that would be displayed on the render.
"This is the render text."
image
string (Optional)
A URL string to an image that would be displayed on the render.
audio
string (Optional)
A URL string to an audio file that would be played on the render.
buttons
Button[] | Button[][] (Optional)
An array or a matrix of Button objects that may appear on the render for interactive purposes. If set as a matrix, each array of buttons will be displayed in a single row.
Button
content
string (Required)
The visible text displayed on the button.
"Click Me"
description
String (Optional)
A tooltip that appears when you hover over the button.
"This button triggers the next part of the process"
on_click
string | Event (Required)
Defines the event that should be triggered when the button is clicked. You can pass data to Transition if needed.
"start_chat"
Event
event
string (Required)
The event name.
"create_page"
payload
Object (Optional)
When triggering an event, you may pass data to the TransitionCase by setting values in payload. In TransitionCase , passed data can be accessed by the prefix payload.
.
Last updated