Agent Script Reference: Variables
Variables let agents deterministically remember information across conversation turns, track progress, and maintain context throughout the session. You define all variables in the variables block, and all subagents in the agent can access the variables.
There are several types of variables:
- regular variable: You can initialize a variable with a default value, and the agent can change the variable’s value.
- linked variable: The value of a linked variable is tied to an output such as an action’s output. Linked variables can’t have a default value.
- system variable: Predefined, prepopulated system variables that you can use in your agent.
Variable names must follow Salesforce developer name standards:
- Begin with a letter, not an underscore.
- Contain only alphanumeric characters and underscores.
- Can’t end with underscore.
- Can’t contain consecutive underscores (__).
- Maximum length of 80 characters.
To reference a variable from the script, use @variables.<variable_name>.
To reference a variable from within reasoning instructions, use {!@variables.<variable_name>}.
Regular variables have these properties:
mutable- Optional. Allows the agent to change the variable’s value. To ensure a variable’s value is never changed, define the variable withoutmutable.description- describes the variable. Optional. If you want the LLM to use reasoning to set the variable’s value, include a description. See Let the LLM set variables with user-entered information (slot filling).label- Optional. The variable’s name as displayed in the UI. By default, the description is generated from the name. For example, if your variable’s name ismy_var, the UI displays the labelMy Var.
Regular variables can have these types:
| Type | Notes | Example |
|---|---|---|
string | Any alphanumeric string without special characters. | name: mutable string = "" |
number | Use for both integers and decimals. For example, 42 or 3.14. Compiles to IEEE 754 double-precision floating point. | age: mutable number, price: mutable number = 99.99 |
boolean | Allowed values are True or False. The value is case-sensitive, so capitalize the first letter. | is_active: mutable boolean = True |
object | Value is a complex JSON object in the form {"key": "value"}. | order_line: mutable object = {"SKU": "abc12344409","count": 42} |
date | Any valid date format. | start_date: mutable date |
id | A Salesforce record ID. | LeadID_Temp: mutable id = "00Q9V00000ZV2xUUAT" |
list[type] | A list of values of the specified type. All primitive types and object type are supported. | flags: mutable list[boolean] = [True, False, True], scores: list[number] = [95, 87.5, 92], obj_list: mutable list[object] = None |
Use None to check whether a variable has a value. You can use None with any variable type. For a string variable, you can also use "" to check if the variable is set to an empty string. When checking string variables in conditional statements, you might want to use both None and "".
For more information, see Agent Script Reference: Conditional Expressions.
A linked variable’s value is tied to a source, such as an action’s output. Linked variables have these restrictions:
- can’t have a default value
- can’t be set by the agent
- can’t be an object or a list
The source field references where the variable gets its value. Supported source namespaces are:
| Namespace | Available Properties | Description |
|---|---|---|
@MessagingSession | Id, MessagingEndUserId, EndUserLanguage | Properties of the messaging session |
@MessagingEndUser | ContactId | Properties of the messaging end user |
@VoiceCall | Id | Properties of the voice call |
Linked variables can have these types:
stringnumberbooleandateid
Agent Script provides predefined, prepopulated system variables that you can use in your agent. To access system variables, use @system_variables.<variable_name>. A system variable is:
- read-only, so you can’t change its value
- predefined, so you don’t define it in the
variablesblock - used in the same places as a regular variable or a linked variable
Currently, @system_variables.user_input is the only system variable.
The user_input system variable contains the customer’s most recent utterance (not the entire conversation history).
The LLM remembers the entire conversation history, so you don’t typically need to use @system_variables.user_input unless you’re passing the last thing a customer said into an action.
In this example, we pass the last customer utterance into a sentiment analysis action. Although the agent’s LLM can also analyze sentiment, we want to use a prompt template action that understands industry-specific terminology and our customer’s rapidly-changing language patterns.
For examples and patterns using variables, see Agent Script Pattern: Using Variables Effectively.
- Pattern: Using Variables Effectively
- Flow of Control
- Reference: Utils