Provision SharePoint agents using Power Automate
Mar 3, 2025 • 4 • 670
Table of contents
Scenario
On a SharePoint front page or document library you can create a SharePoint agent. Totally fine for just creating a couple, but what if the scenario requires the same SharePoint agent setup on a lot of sites. In that case you would automatically want to provision those agents. This way you can immediately impact the behavior, change the default of the welcome message, starter prompts and instructions for the agent. This blog describes how this can be achieved using Power Automate Flow.
Step by step
The steps on high level that needs to be done to provision a SharePoint agent:
All this can be done using the action ‘Send an HTTP request to SharePoint’, no premium license needed.
1. Get site ID
Retrieve the site id of the site for which you want to create an agent. This value is needed in the last step.
2. Get site title
Retrieve the site title of the site for which you want to create an agent. This value is needed in the last step.
3. Check Site Asset Library
Parameter | Value |
---|---|
URL | «the site url» |
TYPE: | POST |
URI: | _api/web/lists/EnsureSiteAssetsLibrary() |
4. Create folder for Copilot
By default the folder is SiteAssets%2FCopilots
.
Parameter | Value |
---|---|
URL | «the site url» |
TYPE: | POST |
URI: | /_api/web/folders/Add(@a1)?@a1=‘SiteAssets%2FCopilots’ |
5. Create agent
Parameter | Value |
---|---|
URL | «the site url» |
TYPE: | POST |
URI: | /_api/web/GetFolderByServerRelativePath(DecodedUrl=’@{substring(variables(‘SiteURL’), indexOf(variables(‘SiteURL’), ‘/sites’))}’)/Files/AddUsingPath(DecodedUrl=‘Name.agent’,EnsureUniqueFileName=true,AutoCheckoutOnInvalidData=true)?&$Select=ServerRelativeUrl,UniqueId,Name,VroomItemID,VroomDriveID,ServerRedirectedUrl&$Expand=ListItemAllFields |
The body is in JSON format which contains the configuration of the SharePoint agent. You can change the defaults conversation starters, define the welcome message and define the description and behavior of the agent.
{
"schemaVersion": "0.2.0",
"customCopilotConfig": {
"conversationStarters": {
"conversationStarterList": [
{
"text": "Summarize any key highlights"
},
{
"text": "Create an FAQ based on these resources"
},
{
"text": "How can I use these resources?"
}
],
"welcomeMessage": {
"text": "Welcome! Enhance your productivity with this agent. Start a conversation by asking a question or selecting one of the suggested prompts."
}
},
"gptDefinition": {
"name": "@{variables('Title')} agent",
"description": "This is an agent curated based on the content from the site.",
"instructions": "Provide helpful, accurate, and relevant information while maintaining a professional and courteous tone.",
"capabilities": [
{
"name": "OneDriveAndSharePoint",
"items_by_sharepoint_ids": [],
"items_by_url": [
{
"url": "@{variables('SiteURL')}",
"name": "@{variables('Title')}",
"site_id": "@{variables('siteid')}",
"web_id": "@{variables('webid')}",
"list_id": "00000000-0000-0000-0000-000000000000",
"unique_id": "00000000-0000-0000-0000-000000000000",
"type": "Site"
}
]
}
]
},
"icon": "@{variables('icon')}"
}
}
The icon in a variable
The default icon is the Copilot logo in base64 format. To have a cleaner view of the body in JSON format I placed the icon in a separate variable.
The body for a document library is a little bit different:
The “items_by_url” node differs from a SharePoint Agent that is created on site level.
You can get the list id by using api call: GET https://{site_url}/_api/web/lists/GetByTitle('List Title')
{
"schemaVersion": "0.2.0",
"customCopilotConfig": {
"conversationStarters": {
"conversationStarterList": [
{
"text": "Summarize any key highlights"
},
{
"text": "Create an FAQ based on these resources"
},
{
"text": "How can I use these resources?"
}
],
"welcomeMessage": {
"text": "Welcome! Enhance your productivity with this agent. Start a conversation by asking a question or selecting one of the suggested prompts."
}
},
"gptDefinition": {
"name": "@{variables('Title')} agent",
"description": "This is an agent curated based on the content from the selected file sources.",
"instructions": "Provide accurate information about the content in the selected files and reply in a formal tone.",
"capabilities": [
{
"name": "OneDriveAndSharePoint",
"items_by_sharepoint_ids": [],
"items_by_url": [
{
"url": "@{variables('SiteURL')}",
"name": "@{variables('Title')}",
"site_id": "@{variables('siteid')}",
"web_id": "@{variables('webid')}",
"list_id": "@{variables('listid')}",
"unique_id": "00000000-0000-0000-0000-000000000000",
"type": "Folder"
}
]
}
]
},
"icon": "@{variables('icon')}"
}
}
Quick link to the agent
The provisioned agent exists in de Site Asset Library and can be accessed over there. You can create a quick link to the agent with the following setup: https://«tenantname».sharepoint.com/sites/«sitename»/SiteAssets/Forms/AllItems.aspx?id=/sites/«sitename»/SiteAssets/Copilots/«agentname».agent&parent=/sites/«sitename»/SiteAssets/Copilots
Conclusion
In this blog, I used a few variables to technically enable the provisioning of the SharePoint agent. Please consider personalizing the welcome message, conversation starter questions, and agent instructions.