-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add location prompt, license info, various typo fixes
- Loading branch information
Showing
21 changed files
with
1,401 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
# [QUICKSTART] 🔥 Prompt your user for location information | ||
|
||
- What if we could ask users for location in a respectful, privacy-protecting manner? | ||
|
||
- This pattern already exists on mobile devices, it should exist on conversational interfaces too, ex: | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/location_iphone.png?raw=true" /> | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/location_demo.gif?raw=true" /> | ||
|
||
Note: The steps below assume you have a working WebEx account + a Cloudflare account with permission to create Workers-- you can port this to any other infrastructure where you can expose a `/location` route that exposes privacy-respecting coarse-grained location information | ||
|
||
## 1) Fetch repo & install deps | ||
|
||
``` | ||
git clone https://github.com/valgaze/speedybot | ||
cd speedybot/examples/location | ||
npm i | ||
``` | ||
|
||
## 2) Get + Set your bot access token | ||
|
||
- Create a bot from scratch here + copy the token: **[https://developer.webex.com/my-apps/new/bot](https://developer.webex.com/my-apps/new/bot)** | ||
|
||
- If you have an existing bot, get its token here (regenerate a new token): **[https://developer.webex.com/my-apps](https://developer.webex.com/my-apps)** | ||
|
||
## 3) Get your bot's URL | ||
|
||
- If you don't have one already, get a **[cloudflare account](https://dash.cloudflare.com/sign-up)** | ||
|
||
- Authenticate your machine with `npx wrangler login` | ||
|
||
- Run the command to deploy the code in this repo to your Worker and get your bot URL | ||
|
||
``` | ||
npm run deploy | ||
``` | ||
|
||
You'll be prompted to open your browser and you'll see an authorization screen like the following asking to enable **[wrangler (Worker's CLI tool)](https://developers.cloudflare.com/workers/wrangler/)** to take actions with your account, click **ALLOW** | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/worker_authorize_wrangler.png" /> | ||
|
||
The URL will look something like https://speedybot-worker-infra.your_username.workers.dev (you'll need it in a minute when we register webhooks) | ||
|
||
## 4) Add your bot token | ||
|
||
From the same directory as the repo run the following command to add a secret called `BOT_TOKEN` and enter your info using **[secrets manager](https://developers.cloudflare.com/workers/configuration/secrets/#secrets-on-deployed-workers)** | ||
|
||
```sh | ||
npx wrangler secret put BOT_TOKEN | ||
``` | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/worker_secret.gif" /> | ||
|
||
## 5) Deploy your agent | ||
|
||
From the same directory as the repo run this command to deploy your agent (now bound with your `BOT_TOKEN` secret) | ||
|
||
``` | ||
npm run deploy | ||
``` | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/worker_deploy.gif" /> | ||
|
||
## 6) Register your webhooks | ||
|
||
- Right now if you try to interact with your "deployed" agent nothing happens, nobody is "home" to answer the knock at the door | ||
|
||
- Make a note of the URL of the deployed function (ie https://speedybot-worker-infra.your_username.workers.dev) | ||
|
||
- Hop on over to the **[SpeedyBot Garage (https://speedybot.js.org/garage)](https://speedybot.js.org/garage)**, enter your access token, select the Webhooks tab, and then **Add New Webhook** and add your Worker's URL and (optionally) a webhook secret | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/webhook_steps.gif" /> | ||
|
||
## 6a) Supply your Webhook "secret" to your Worker | ||
|
||
Even though it's "optional", it's a really, really good idea to set a Webhook Secret too so you can make sure incoming requests are the real deal. For more detail, see **[https://speedybot.js.org/webhooks#securing-webhooks](https://speedybot.js.org/webhooks#securing-webhooks)** | ||
|
||
To supply your Worker with a webhook secret, set a secret called WEBHOOK_SECRET which you'll need to supply to your Worker like you did with your `BOT_TOKEN` value | ||
|
||
```sh | ||
npx wrangler secret put WEBHOOK_SECRET | ||
``` | ||
|
||
## 7) Take it for a spin | ||
|
||
- After connecting webhooks, take it for a spin + say "location" or tap the Location Integration chip: | ||
|
||
<img src="https://raw.githubusercontent.com/valgaze/speedybot-utils/main/assets/various/location_demo.gif?raw=true" /> | ||
|
||
## Some notes | ||
|
||
- This is a proof of concept where the location-enriched functionality is broken out into a separate file | ||
|
||
- We expose the messageId on the URL which in and of itself isn't a security issue, but depending on the platform you deploy to you could take advantage of encryption to scramble/unscramble the messageId | ||
|
||
- The service used in this instance gives at best a very rough/coarse-grained amount of detail of a user's "location"-- the less detail you agent needs, the better |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# http://editorconfig.org | ||
root = true | ||
|
||
[*] | ||
indent_style = tab | ||
tab_width = 2 | ||
end_of_line = lf | ||
charset = utf-8 | ||
trim_trailing_whitespace = true | ||
insert_final_newline = true | ||
|
||
[*.yml] | ||
indent_style = space |
Oops, something went wrong.