Goal : Interact with Magic xpi using copilot prompt in natural language via a specialized declarative agent
data:image/s3,"s3://crabby-images/81129/811290b29c9582c8e1c40efacb0a0f645bb4b18b" alt=""
Prerequisites :
- Microsoft tenant with your admin user or user that have enough rights to publish and allow custom upload apps
- Copilot For Microsoft 365 License (1 user for test)
- Microsoft 365 Business Basic License (1 user for test)
- Visual Code with Teams Toolkit plugin installed
1/ Open your Magic xpi Studio
Create an HTTP trigger with 1 method (GetOrderDetail) with 1 argument (OrderNum)
data:image/s3,"s3://crabby-images/78ebd/78ebd20a8898ce257f593ebf32a49f88497b7963" alt=""
2/ Design a Flow that retrieves the detail of the order according to OrderNum parameter and answers a JSON message with the related information
(*) In my case, i’m retrieving the detail of the order from a Prestashop system via MySQL Database
data:image/s3,"s3://crabby-images/1e5fa/1e5fa54b968c4cb4367e3617b58877760b0b1755" alt=""
My step mapper (get Order det. from Prestashop) should be like this (for my case)
data:image/s3,"s3://crabby-images/d28d8/d28d8aadd5e8634f9baaf3ad17d5c92af7f95007" alt=""
data:image/s3,"s3://crabby-images/00f6f/00f6f83083d1e401510cefdb8dc8c7f796c932ae" alt=""
3/ Build the Json response
data:image/s3,"s3://crabby-images/bca25/bca259bda2d8599b91df95675e3d72e59e0b9791" alt=""
4/ Build and start your project.
5/ Check with Postman that you can trigger the Magic xpi Flow by passing the orderNum
data:image/s3,"s3://crabby-images/3e442/3e4425bb866a942e26333116fa5cefc6a72adf42" alt=""
5/ Start your Visual Code and install the Teams Toolkit plugin
Menu: View=>Extensions =>enter Teams Toolkit
data:image/s3,"s3://crabby-images/67be4/67be4e76ff7f1734af932106ffbc01b37a29781e" alt=""
6/ After installation, sign on https://admin.teams.microsoft.com
Allow Upload Custom App
data:image/s3,"s3://crabby-images/38e47/38e472815f0cf0782c32a41df9f175d5e586dfba" alt=""
Go back to Visual Code, choose on the left menu Teams Toolkit
data:image/s3,"s3://crabby-images/0e2cb/0e2cba575e30c97d2ea8670daa907890c7c30258" alt=""
Sign in with your admin user on the menu Accounts.
!! You should check that these 2 options below are enabled:
- Custom App Upload Enabled
- Copilot Access Enabled
(*) Copilot Access Enabled can be delayed to be activated (24h)
7/ At this point, you need to get a Magic xpi Yaml file from your endpoints
You can use Postman for that.
8/ Go Back to your visual code
Choose TeamsToolkit menu and create a Declarative Agent
data:image/s3,"s3://crabby-images/d6cd0/d6cd05b6c88195d4103bbc68a23a6e513787d0d4" alt=""
Choose Addplugin=>Start With OpenApi Description Document>browser and give your yaml file
Make your changes in the project.
You can use snippet UI (adaptivecards.io) to handle the Magic xpi JSON response.
9/ Provision the project and if it’s ok then Publish your agent (apps)
Menu LIFECYCLE => Provision
data:image/s3,"s3://crabby-images/128df/128dfd9a80d46643334ac86f6d229651a5a81869" alt=""
data:image/s3,"s3://crabby-images/1c107/1c1079e51b719f1e608dc6ea02d47c17da9d2bee" alt=""
data:image/s3,"s3://crabby-images/2d4fd/2d4fd9f56d5cf36db020bbd8a78c933190a32d4a" alt=""
10/ Go to your teams admin portal
You must approve the pending custom apps (if it’s newly created you should see 1 in Submitted custom apps)
The first time, App Status should be « Blocked », you must have « Allowed »
data:image/s3,"s3://crabby-images/b84c2/b84c20f55173860d164a51f94554f4eabd60890b" alt=""
data:image/s3,"s3://crabby-images/c11f7/c11f704c8d71666816bb2336b4ed444b62ab3045" alt=""
Choose Publish by clicking on the agent below
data:image/s3,"s3://crabby-images/113b7/113b7b348bad548b09859cd5ab1d88e91ce402db" alt=""
7/ Go to your Copilot prompt
Select You agent on the Right pane
On the prompt: you can ask your question in french or english to get the order total and more
data:image/s3,"s3://crabby-images/e64f6/e64f65100f740cc931ad64c502d4ced2fac51d34" alt=""
data:image/s3,"s3://crabby-images/5043f/5043f1bcf8c8d430873855a63e2dda7a02fac0a2" alt=""
The first time you ask your question, you should receive this message related to your agent and you have to authorize (« Always » or « Once »)
data:image/s3,"s3://crabby-images/3bca9/3bca919b9ed24a215a18be27103cc98e24dcc3fc" alt=""
15/ You can handle exception in the Magic process if the order is not found
data:image/s3,"s3://crabby-images/8d673/8d6731f4666ac256ab82450134c4b4ae1d77a9e0" alt=""
or if there is no delivery date then, you can get :
data:image/s3,"s3://crabby-images/c8eb7/c8eb7d1a1ac73ca75406f6dfeca8d1faf24bd35d" alt=""
8/ If you enter a sentence without giving the Order Number then Copilot will ask you to pass it
data:image/s3,"s3://crabby-images/2d37c/2d37cba9d55ba2c19b9349e4ea41bb88f1f8c373" alt=""
9/ You can ask for the order detail as well
Ask for the total first
data:image/s3,"s3://crabby-images/68768/68768438096cc24b28b0afebef9b653b080f35d6" alt=""
then ask for the detail (you don’t need to enter the order number) as we are in the same context
data:image/s3,"s3://crabby-images/b86a7/b86a7c2b1e8eac486507587cb2c8e8ba4fc5ee77" alt=""
(*) You can bind the magic xpi json array to a ColumnSet in the adaptivecard.
10/ Each time you enter an Order Number in the prompt, a Magic xpi flow is triggered receiving the order num
data:image/s3,"s3://crabby-images/89e91/89e916667b3b49aaa10eab570f1884dc18ff4816" alt=""
10/ With this architecture, you can design as many flows as you want in Magic xpi (with any Business rules), expose them in the copilot agent (via yaml file) and interact in a natural language.
Don’t hesitate to contact me if you are interested to implement it.