Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zentered/vercel-preview-url
GitHub Action to receive the deployment preview URL from Vercel
https://github.com/zentered/vercel-preview-url
action deployment github vercel vercel-deployment vercel-shorturl
Last synced: 3 months ago
JSON representation
GitHub Action to receive the deployment preview URL from Vercel
- Host: GitHub
- URL: https://github.com/zentered/vercel-preview-url
- Owner: zentered
- License: mit
- Created: 2021-01-09T15:07:58.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-25T23:05:29.000Z (3 months ago)
- Last Synced: 2024-10-26T11:37:54.159Z (3 months ago)
- Topics: action, deployment, github, vercel, vercel-deployment, vercel-shorturl
- Language: JavaScript
- Homepage: https://github.com/zentered/vercel-preview-url#readme
- Size: 2.41 MB
- Stars: 28
- Watchers: 2
- Forks: 10
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Vercel Preview URL
![Test](https://github.com/zentered/vercel-preview-url/workflows/Test/badge.svg)
[![Integration Test](https://github.com/PatrickHeneise/vercel-preview-action-test/actions/workflows/integration.yml/badge.svg)](https://github.com/PatrickHeneise/vercel-preview-action-test/actions/workflows/integration.yml)
![Release](https://github.com/zentered/vercel-preview-url/workflows/Publish/badge.svg)
[![semantic-release: conventional](https://img.shields.io/badge/semantic--release-conventional-e10079?logo=semantic-release)](https://github.com/semantic-release/semantic-release)
[![Conventional Commits](https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg)](https://conventionalcommits.org)Retrieve the preview URL from the Vercel API, filtered by the repo and branch. The URL can then be used for further end-to-end tests, link checks and other PR integrations/actions.
The main difference to [Capture Vercel Preview URL](https://github.com/marketplace/actions/capture-vercel-preview-url) is that the action runs on `push` and `pull_request`, not on `issue_comment`. This enables 3rd party GitHub integrations to report directly on the Pull Request.
## Table of Contents
- [Vercel Preview URL](#vercel-preview-url)
- [Table of Contents](#table-of-contents)
- [Usage](#usage)
- [Vercel Project ID](#vercel-project-id)
- [Environment Variables / Secret](#environment-variables--secret)
- [Inputs](#inputs)
- [Outputs](#outputs)
- [Contributing](#contributing)
- [License](#license)## Usage
- [Create a Vercel API Token](https://vercel.com/account/tokens)
- See [Integration Test / Demo](https://github.com/PatrickHeneise/vercel-preview-action-test/blob/main/.github/workflows/integration.yml)Vercel needs a little time to build the preview, you can check the average build time in your deployments and add the seconds plus a little to a `sleep` action, to wait until the deployment is `READY`.
Instead of an arbitrary time, the [Await for Vercel deployment](https://github.com/marketplace/actions/await-for-vercel-deployment) Action can be used.
```yaml
- run: sleep 30
- name: vercel-preview-url
uses: zentered/[email protected]
id: vercel_preview_url
env:
VERCEL_TOKEN: ${{ secrets.VERCEL_TOKEN }}
with:
vercel_project_id: 'prj_XYZ123'
- name: Get URL
run: echo "https://${{ steps.vercel_preview_url.outputs.preview_url }}"
```### Vercel Project ID
Your project name is not the same as the project ID. You can find the project ID in the Project Settings, it starts with `prj_`:
![vercel project id](.github/assets/projectid.png)
## Environment Variables / Secret
In the repository, go to "Settings", then "Secrets" and add "VERCEL_TOKEN", the value you can retrieve on your [Vercel account](https://vercel.com/account/tokens).
By optionally setting `SEARCH_BRANCH_NAME` as an environment variable, you can override the branch name used to search for deployments in Vercel.
This environment variable is useful in cases where GITHUB_REF becomes the default branch, such as when commenting on pull requests or adding labels.## Inputs
To see more information on inputs, see the [Vercel Documentation](https://vercel.com/docs/rest-api#endpoints/deployments/list-deployments).
| Name | Requirement | Type | Description |
| ------------------- | ----------- | --------- | ---------------------------- |
| `vercel_team_id` | optional | string | Team id |
| `vercel_app` | optional | string | Name of the deployment |
| `vercel_from` | optional | timestamp | Deployment after this date |
| `vercel_project_id` | optional | string | Vercel project id |
| `vercel_since` | optional | timestamp | Deployment since this date |
| `vercel_state` | optional | string | Filter on state |
| `vercel_target` | optional | string | Deployment environment |
| `vercel_to` | optional | timestamp | Deployment before this date |
| `vercel_until` | optional | timestamp | Deployment before this date |
| `vercel_users` | optional | string | Filter on created by user(s) |## Outputs
| Name | Description |
| ------------------ | --------------------------------------------------------------------------------------------------------------------------------- |
| `preview_url` | A string with the unique URL of the deployment. If it hasn't finished uploading (is incomplete), the value will be null |
| `deployment_state` | A string with the current deployment state, it could be one of the following QUEUED, BUILDING, READY, or ERROR. |
| `branch_alias` | A string with the [branch alias](https://vercel.com/docs/cli/alias), that is a custom domain that Vercel creates for that branch. |## Contributing
See [CONTRIBUTING](CONTRIBUTING.md).
## License
See [LICENSE](LICENSE).