wrangler-action/README.md

243 lines
8.1 KiB
Markdown
Raw Normal View History

2019-10-14 22:49:39 +02:00
# Wrangler GitHub Action
2022-05-09 12:49:03 +02:00
Easy-to-use GitHub Action to use [Wrangler](https://developers.cloudflare.com/workers/cli-wrangler/). Makes deploying Workers, Pages or modifying R2 easy to do.
- Wrangler v1 is no longer supported.
2023-08-07 21:29:10 +02:00
- Global API key & Email Auth no longer supported
2022-05-09 12:49:03 +02:00
[Refer to Changelog for more information](CHANGELOG.md).
2019-10-14 22:49:39 +02:00
## Usage
2023-08-07 21:57:12 +02:00
Add `wrangler-action` to the workflow for your Workers/Pages application. The below example will deploy a Worker on a `git push` to the `main` branch:
2019-10-14 22:49:39 +02:00
```yaml
2019-10-25 00:31:04 +02:00
name: Deploy
2019-10-14 22:49:39 +02:00
on:
push:
branches:
2022-05-09 12:49:03 +02:00
- main
2019-10-14 22:49:39 +02:00
jobs:
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
- uses: actions/checkout@v2
2023-08-07 21:57:12 +02:00
- name: Deploy
uses: cloudflare/wrangler-action@3.0.0
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
2019-10-14 22:49:39 +02:00
```
## Authentication
You'll need to configure Wrangler using GitHub's Secrets feature - go to "Settings -> Secrets" and add your Cloudflare API token (for help finding this, see the [Workers documentation](https://developers.cloudflare.com/workers/quickstart/#api-token)). Your API token is encrypted by GitHub, and the action won't print it into logs, so it should be safe!
With your API token set as a secret for your repository, pass it to the action in the `with` block of your workflow. Below, I've set the secret name to `CF_API_TOKEN`:
2019-10-14 22:49:39 +02:00
```yaml
jobs:
deploy:
name: Deploy
steps:
uses: cloudflare/wrangler-action@3.0.0
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
```
2019-10-14 22:49:39 +02:00
## Configuration
If you need to install a specific version of Wrangler to use for deployment, you can also pass the input `wranglerVersion` to install a specific version of Wrangler from NPM. This should be a [SemVer](https://semver.org/)-style version number, such as `2.20.0`:
```yaml
jobs:
deploy:
steps:
uses: cloudflare/wrangler-action@3.0.0
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
wranglerVersion: "2.20.0"
```
Optionally, you can also pass a `workingDirectory` key to the action. This will allow you to specify a subdirectory of the repo to run the Wrangler command from.
```yaml
jobs:
deploy:
steps:
uses: cloudflare/wrangler-action@3.0.0
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
workingDirectory: "subfoldername"
```
[Worker secrets](https://developers.cloudflare.com/workers/tooling/wrangler/secrets/) can optionally be passed in via `secrets` as a string of names separated by newlines. Each secret name must match the name of an environment variable specified in the `env` field. This creates or replaces the value for the Worker secret using the `wrangler secret put` command.
2020-06-16 06:09:55 +02:00
```yaml
jobs:
deploy:
steps:
uses: cloudflare/wrangler-action@3.0.0
2020-06-16 06:09:55 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
secrets: |
SECRET1
SECRET2
2020-06-16 06:09:55 +02:00
env:
SECRET1: ${{ secrets.SECRET1 }}
SECRET2: ${{ secrets.SECRET2 }}
```
2023-08-07 21:57:12 +02:00
If you need to run additional shell commands before or after your command, you can specify them as input to `preCommands` (before `deploy`) or `postCommands` (after `deploy`). These can include additional `wrangler` commands (that is, `whoami`, `kv:key put`) or any other commands available inside the `wrangler-action` context.
2020-08-07 23:16:42 +02:00
```yaml
jobs:
deploy:
steps:
uses: cloudflare/wrangler-action@3.0.0
2020-08-07 23:16:42 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
preCommands: echo "*** pre command ***"
postCommands: |
echo "*** post commands ***"
wrangler kv:key put --binding=MY_KV key2 value2
echo "******"
```
2022-05-09 12:49:03 +02:00
You can use the `command` option to do specific actions such as running `wrangler whoami` against your project:
2020-08-12 05:46:42 +02:00
```yaml
jobs:
deploy:
steps:
uses: cloudflare/wrangler-action@3.0.0
2020-08-12 05:46:42 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
2022-05-09 12:49:03 +02:00
command: whoami
2020-08-12 05:46:42 +02:00
```
2019-10-17 23:29:40 +02:00
## Use cases
2022-05-09 12:49:03 +02:00
### Deploy when commits are merged to main
2019-10-17 23:29:40 +02:00
2022-05-09 12:49:03 +02:00
The above workflow examples have already shown how to run `wrangler-action` when new commits are merged to the main branch. For most developers, this workflow will easily replace manual deploys and be a great first integration step with `wrangler-action`:
2019-10-17 23:29:40 +02:00
```yaml
on:
push:
branches:
2022-05-09 12:49:03 +02:00
- main
2019-10-17 23:29:40 +02:00
jobs:
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
2022-05-09 12:49:03 +02:00
- uses: actions/checkout@v3
2023-08-07 21:57:12 +02:00
- name: Deploy
uses: cloudflare/wrangler-action@3.0.0
2019-10-17 23:29:40 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
2019-10-17 23:29:40 +02:00
```
2022-05-09 12:49:03 +02:00
Note that there are a number of possible events, like `push`, that can be used to trigger a workflow. For more details on the events available, refer to the [GitHub Actions documentation](https://help.github.com/en/articles/workflow-syntax-for-github-actions#on).
### Deploy your Pages site (production & preview)
2023-08-07 21:57:12 +02:00
If you want to deploy your Pages project with GitHub Actions rather than the built-in continous integration (CI), then this is a great way to do it. Wrangler 2 will populate the commit message and branch for you. You only need to pass the project name. If a push to a non-production branch is done, it will deploy as a preview deployment:
2022-05-09 12:49:03 +02:00
```yaml
on: [push]
jobs:
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
- uses: actions/checkout@v3
2023-08-07 21:57:12 +02:00
- name: Deploy
uses: cloudflare/wrangler-action@3.0.0
2022-05-09 12:49:03 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
accountId: ${{ secrets.CF_ACCOUNT_ID }}
2023-08-07 21:57:12 +02:00
command: pages deploy --project-name=example
2022-05-09 12:49:03 +02:00
```
2019-10-17 23:29:40 +02:00
### Deploying on a schedule
2022-05-09 12:49:03 +02:00
If you would like to deploy your Workers application on a recurring basis for example, every hour, or daily the `schedule` trigger allows you to use cron syntax to define a workflow schedule. The below example will deploy at the beginning of every hour:
2019-10-17 23:29:40 +02:00
```yaml
on:
schedule:
- cron: "0 * * * *"
2019-10-17 23:29:40 +02:00
jobs:
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
2022-05-09 12:49:03 +02:00
- uses: actions/checkout@v3
2023-08-07 21:57:12 +02:00
- name: Deploy app
uses: cloudflare/wrangler-action@3.0.0
2019-10-17 23:29:40 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
2019-10-17 23:29:40 +02:00
```
If you need help defining the correct cron syntax, check out [crontab.guru](https://crontab.guru/), which provides a friendly user interface for validating your cron schedule.
2022-05-09 12:49:03 +02:00
### Manually triggering a deployment
2019-10-17 23:29:40 +02:00
2022-05-09 12:49:03 +02:00
If you need to trigger a workflow at-will, you can use GitHub's `workflow_dispatch` [event](https://docs.github.com/en/actions/reference/events-that-trigger-workflows#workflow_dispatch) in your workflow file. By setting your workflow to trigger on that event, you will be able to deploy your application via the GitHub UI. The UI also accepts inputs that can be used to configure the action:
2019-10-17 23:29:40 +02:00
```yaml
on:
workflow_dispatch:
inputs:
environment:
description: "Choose an environment to deploy to: <dev|staging|prod>"
required: true
default: "dev"
2019-10-17 23:29:40 +02:00
jobs:
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
2022-05-09 12:49:03 +02:00
- uses: actions/checkout@v3
2023-08-07 21:57:12 +02:00
- name: Deploy app
uses: cloudflare/wrangler-action@3.0.0
2019-10-17 23:29:40 +02:00
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
2023-08-07 21:57:12 +02:00
command: deploy --env ${{ github.event.inputs.environment }}
2019-10-17 23:29:40 +02:00
```
2022-05-09 12:49:03 +02:00
For more advanced usage or to programmatically trigger the workflow from scripts, refer to [the GitHub documentation](https://docs.github.com/en/rest/reference/actions#create-a-workflow-dispatch-event) for making API calls.
2019-10-17 23:29:40 +02:00
2019-10-14 22:49:39 +02:00
## Troubleshooting
### "I just started using Workers/Wrangler and I don't know what this is!"
2022-05-09 12:49:03 +02:00
Refer to the [Quick Start guide](https://developers.cloudflare.com/workers/quickstart) to get started. Once you have a Workers application, you may want to set it up to automatically deploy from GitHub whenever you change your project.
2019-10-14 22:49:39 +02:00
2022-05-09 12:49:03 +02:00
### "[ERROR] No account id found, quitting.."
2019-10-14 22:49:39 +02:00
2022-05-09 12:49:03 +02:00
You will need to add `account_id = ""` in your `wrangler.toml` file or set `accountId` in this GitHub Action.
2019-10-14 22:49:39 +02:00
2019-10-14 22:58:01 +02:00
```yaml
2022-05-09 12:49:03 +02:00
on: [push]
2019-10-14 22:49:39 +02:00
jobs:
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
2022-05-09 12:49:03 +02:00
- uses: actions/checkout@v3
2023-08-07 21:57:12 +02:00
- name: Deploy app
uses: cloudflare/wrangler-action@3.0.0
with:
apiToken: ${{ secrets.CF_API_TOKEN }}
2022-05-09 12:49:03 +02:00
accountId: ${{ secrets.CF_ACCOUNT_ID }}
```