Help us improve
Share bugs, ideas, or general feedback.
From copilot-studio
Adds global variables to Copilot Studio agents that persist across conversation topics, with optional visibility to the AI orchestrator. Use for session-wide state like user preferences or counters.
npx claudepluginhub microsoft/skills-for-copilot-studio --plugin copilot-studioHow this skill is triggered — by the user, by Claude, or both
Slash command
/copilot-studio:add-global-variable <variable name and purpose><variable name and purpose>copilot-studio-authorThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
Create a global variable that persists across all topics within a conversation.
Generates Copilot Studio topic YAML files for agent conversations, auto-discovering agents, matching templates, validating schema kinds, and using unique node IDs.
Guides users through 6-phase interview to define custom agent purpose, capabilities, triggers, output format, and rules, then generates agent file.
Builds, modifies, debugs, and deploys Salesforce Agentforce AI agents using Agent Script, .agent files, aiAuthoringBundle metadata, and sf CLI commands like generate, preview, publish, test.
Share bugs, ideas, or general feedback.
Create a global variable that persists across all topics within a conversation.
Auto-discover the agent directory:
Glob: **/agent.mcs.yml
Use the top-level agent. NEVER hardcode an agent name.
Read settings.mcs.yml to get the schemaName prefix:
Read: <agent-dir>/settings.mcs.yml
Extract the root-level schemaName value (e.g., copilots_header_cre3c_fullagent).
Determine from the user:
LastDiscussedCity)aIVisibility)Create the variable file at <agent-dir>/variables/<VariableName>.mcs.yml:
# Name: <Human-readable Name>
# <Description>
name: <VariableName>
aIVisibility: <UseInAIContext or HideFromAIContext>
scope: Conversation
description: <Description of what the variable stores>
schemaName: <prefix>.globalvariable.<VariableName>
kind: GlobalVariableComponent
defaultValue: <DEFAULT or specific value>
name — PascalCase identifier. This is how topics reference the variable: Global.<name> (e.g., Global.LastDiscussedCity).aIVisibility — Controls orchestrator awareness:
UseInAIContext — The orchestrator can read and reason about this variable. Use when the variable influences routing or response generation (e.g., user preferences, conversation state the AI should track).HideFromAIContext — The variable exists but the orchestrator doesn't see it. Use for internal bookkeeping (e.g., counters, flags) that topics use but the AI doesn't need to reason about.scope: Conversation — Always Conversation for global variables (persists for the session).schemaName — Must follow the pattern <agent-schemaName>.globalvariable.<VariableName>. Read the prefix from settings.mcs.yml.defaultValue — Initial value. Use DEFAULT if no specific initial value is needed.Topics reference global variables with the Global. prefix:
# Reading a global variable in a condition
- kind: ConditionGroup
id: conditionGroup_Xk9mPq
conditions:
- id: conditionItem_Lw3nRs
condition: =!IsBlank(Global.LastDiscussedCity)
actions:
- kind: SendActivity
id: sendMessage_Yt7vBw
activity:
text:
- "Last time we discussed {Global.LastDiscussedCity}."
# Setting a global variable from a topic
- kind: SetTextVariable
id: setTextVariable_Qp4kMn
variable: Global.LastDiscussedCity
value: =Topic.CityName
UseInAIContext)=$"{Global.VarName}". This enables routing to different SharePoint folders or websites per user (e.g., by geolocation or department). See /copilot-studio:add-knowledge for the full pattern. Important: the variable value must be a clean, direct URL — not a SharePoint AllItems.aspx link with query parameters.