This action slug and expose some github variables.
Slug
a variable will
- put the variable content in lower case
- replace any character by
-
except0-9
,a-z
, and.
- remove leading and trailing
-
character - limit the string size to 63 characters
Others Slug
-ish commands are available:
Slug URL
a variable will be like theslug
variable but the.
character will also be replaced by-
Short SHA
a variable will limit the string size to 8 characters
- name: Inject slug/short variables
uses: rlespinasse/github-slug-action@v2.x
- name: Print slug/short variables
run: |
echo "Slug variables"
echo " ref : ${{ env.GITHUB_REF_SLUG }}"
echo " head ref : ${{ env.GITHUB_HEAD_REF_SLUG }}"
echo " base ref : ${{ env.GITHUB_BASE_REF_SLUG }}"
echo " event ref : ${{ env.GITHUB_EVENT_REF_SLUG }}"
echo " repository : ${{ env.GITHUB_REPOSITORY_SLUG }}"
echo "Slug URL variables"
echo " ref : ${{ env.GITHUB_REF_SLUG_URL }}"
echo " head ref : ${{ env.GITHUB_HEAD_REF_SLUG_URL }}"
echo " base ref : ${{ env.GITHUB_BASE_REF_SLUG_URL }}"
echo " event ref : ${{ env.GITHUB_EVENT_REF_SLUG_URL }}"
echo " repository : ${{ env.GITHUB_REPOSITORY_SLUG_URL }}"
echo "Short SHA variables"
echo " sha : ${{ env.GITHUB_SHA_SHORT }}"
Read default environment variables page for more information.
Slug the environment variable GITHUB_REF
The branch or tag ref that triggered the workflow. If neither a branch or tag is available for the event type, the variable will not exist.
GITHUB_REF | GITHUB_REF_SLUG | GITHUB_REF_SLUG_URL |
---|---|---|
refs/heads/master | master | master |
refs/heads/feat/new_feature | feat-new-feature | feat-new-feature |
refs/tags/v1.0.0 | v1.0.0 | v1-0-0 |
refs/tags/product@1.0.0-rc.2 | product-1.0.0-rc.2 | product-1-0-0-rc-2 |
refs/heads/New_Awesome_Product | new-awesome-product | new-awesome-product |
NOTE : GITHUB_REF_SLUG_URL is design to be used as subdomain in an URL.
Additional variables (only set for forked repositories) :
GITHUB_HEAD_REF_SLUG
/GITHUB_HEAD_REF_SLUG_URL
, The branch of the head repository GITHUB_HEAD_REFGITHUB_BASE_REF_SLUG
/GITHUB_BASE_REF_SLUG_URL
, The branch of the base repository GITHUB_BASE_REF
Additional variables (only set for create, and delete webhook events with ref
data) :
GITHUB_EVENT_REF_SLUG
/GITHUB_EVENT_REF_SLUG_URL
, The git reference resource associated to the webhook.
Slug the environment variable GITHUB_REPOSITORY
The owner and repository name.
GITHUB_REPOSITORY | GITHUB_REPOSITORY_SLUG | GITHUB_REPOSITORY_SLUG_URL |
---|---|---|
octocat/Hello-World | octocat-hello-world | octocat-hello-world |
rlespinasse/Hello-World.go | rlespinasse-hello-world.go | rlespinasse-hello-world-go |
NOTE : GITHUB_REPOSITORY_SLUG_URL is design to be used as subdomain in an URL.
Short the environment variable GITHUB_SHA
The commit SHA that triggered the workflow
GITHUB_SHA | GITHUB_SHA_SHORT |
---|---|
ffac537e6cbbf934b08745a378932722df287a53 | ffac537e |
In an URL, use <GITHUB_VARIABLE>_SLUG_URL
instead of <GITHUB_VARIABLE>_SLUG as subdomain to be compliant.
NOTE : <GITHUBVARIABLE>_SLUG can be used in an URL only as part of the _resource path.
- name: Inject slug/short variables
uses: rlespinasse/github-slug-action@v2.x
- name: Deploy dummy application using slug in the 'subdomain' part
run: |
./deploy-application.sh --url "https://${{ env.<GITHUB_VARIABLE>_SLUG_URL }}.staging.app.mycompagny.com"
- name: Deploy dummy application using slug in the 'resource path' part
run: |
./deploy-application.sh --url "https://staging.app.mycompagny.com/${{ env.<GITHUB_VARIABLE>_SLUG }}"
If your workflow fail on the Set up job
task with this kind of log :
Download action repository 'rlespinasse/github-slug-action@master'
##[error]An action could not be found at the URI 'https://api.github.com/repos/rlespinasse/github-slug-action/tarball/master'
Use the current branch v2.x
or a version tag (see releases pages).
The master branch EOL is set on 2020-10-25 after a 6-month deprecation period (more information on the EOL issue)
When using this action on Windows or Macos workflows, A ##[error]Container action is only supported on Linux
error can be see in your workflow logs.
Currently, this action don't support a system other than Linux due to Github Action Limitation on Container
-based action.
On the v3.x
branch, this GitHub action have been rewrite to be able to run on Windows or Macos workflow.
- name: Inject slug/short variables
uses: rlespinasse/github-slug-action@v3.x