11 Commits
v1.2.1 ... v1

Author SHA1 Message Date
Romain Lespinasse
a4879db1eb feat: support GHES step output management 2022-10-31 19:44:04 +01:00
Vin
1d53af49fb fix: use environment file to manage outputs 2022-10-15 21:27:02 +02:00
Romain Lespinasse
f1c7463d0d fix(slug): remove trailing hypens if any after reduction 2022-06-16 09:55:04 +02:00
Romain Lespinasse
4e258f56ef fix(slug_url): remove ending hypen if any 2022-06-15 16:06:49 +02:00
rlespinasse
930d4521cc Revert "fix(slug_url): remove ending hypen if any"
This reverts commit cb3e46ca61.
2022-06-15 15:51:30 +02:00
Romain Lespinasse
cb3e46ca61 fix(slug_url): remove ending hypen if any 2022-06-15 15:48:10 +02:00
rlespinasse
cb5f2aad22 ci: fix typo 2022-04-17 20:06:56 +02:00
rlespinasse
1ce1e1b126 docs: improve sections 2022-04-17 19:48:08 +02:00
Romain Lespinasse
38f26c3445 feat: expose slug values as outputs 2022-04-16 21:00:34 +02:00
Romain Lespinasse
ae545a3d5d fix: remove dashes group substitution
Co-authored-by: Gaetan BOGAERT <gbogaert62@gmail.com>
2022-04-08 21:39:31 +02:00
Romain Lespinasse
1300b1ecaf fix(slug_url): replace underscore
To be compliant with Hostname syntax, we need to remove underscores from the slug value.

Since the hostname is part of the URL, we update the SLUG_URL values instead of creating a new SLUG_HOSTNAME (for example).
2022-04-08 20:38:08 +02:00
4 changed files with 170 additions and 77 deletions

View File

@@ -17,82 +17,88 @@ jobs:
# Test 1 # Test 1
- name: Slugify key only - name: Slugify key only
id: slugify-key-only
uses: ./ uses: ./
with: with:
key: KEY_TEST key: KEY_ONLY
env: env:
KEY_TEST: Key_Test.values KEY_ONLY: "refs/head/$-Key_Only.test--value-%-+"
- name: Validate // Slugify key only - name: Validate // Slugify key only
run: | run: |
[[ "${{ env.KEY_TEST }}" == "Key_Test.values" ]] [[ "${{ env.KEY_ONLY }}" == "refs/head/$-Key_Only.test--value-%-+" ]]
[[ "${{ env.KEY_TEST_SLUG }}" == "key_test.values" ]] [[ "${{ env.KEY_ONLY_SLUG }}" == "key_only.test--value" ]]
[[ "${{ env.KEY_TEST_SLUG_CS }}" == "Key_Test.values" ]] [[ "${{ env.KEY_ONLY_SLUG_CS }}" == "Key_Only.test--value" ]]
[[ "${{ env.KEY_TEST_SLUG_URL }}" == "key_test-values" ]] [[ "${{ env.KEY_ONLY_SLUG_URL }}" == "key-only-test--value" ]]
[[ "${{ env.KEY_TEST_SLUG_URL_CS }}" == "Key_Test-values" ]] [[ "${{ env.KEY_ONLY_SLUG_URL_CS }}" == "Key-Only-test--value" ]]
[[ "${{ env.KEY_ONLY }}" == "${{ steps.slugify-key-only.outputs.value }}" ]]
[[ "${{ env.KEY_ONLY_SLUG }}" == "${{ steps.slugify-key-only.outputs.slug }}" ]]
[[ "${{ env.KEY_ONLY_SLUG_CS }}" == "${{ steps.slugify-key-only.outputs.slug-cs }}" ]]
[[ "${{ env.KEY_ONLY_SLUG_URL }}" == "${{ steps.slugify-key-only.outputs.slug-url }}" ]]
[[ "${{ env.KEY_ONLY_SLUG_URL_CS }}" == "${{ steps.slugify-key-only.outputs.slug-url-cs }}" ]]
shell: bash shell: bash
# Test 2 # Test 2
- name: Slugify key only with prefix - name: Slugify key only with prefix
uses: ./ uses: ./
with: with:
key: KEY_TEST key: KEY_ONLY_WITH_PREFIX
prefix: CI_ prefix: CI_
env: env:
KEY_TEST: Key_Test.values KEY_ONLY_WITH_PREFIX: ${{ env.KEY_ONLY }}
- name: Validate // Slugify key only with prefix - name: Validate // Slugify key only with prefix
run: | run: |
[[ "${{ env.CI_KEY_TEST }}" == "${{ env.KEY_TEST }}" ]] [[ "${{ env.CI_KEY_ONLY_WITH_PREFIX }}" == "${{ env.KEY_ONLY }}" ]]
[[ "${{ env.CI_KEY_TEST_SLUG }}" == "${{ env.KEY_TEST_SLUG }}" ]] [[ "${{ env.CI_KEY_ONLY_WITH_PREFIX_SLUG }}" == "${{ env.KEY_ONLY_SLUG }}" ]]
[[ "${{ env.CI_KEY_TEST_SLUG_CS }}" == "${{ env.KEY_TEST_SLUG_CS }}" ]] [[ "${{ env.CI_KEY_ONLY_WITH_PREFIX_SLUG_CS }}" == "${{ env.KEY_ONLY_SLUG_CS }}" ]]
[[ "${{ env.CI_KEY_TEST_SLUG_URL }}" == "${{ env.KEY_TEST_SLUG_URL }}" ]] [[ "${{ env.CI_KEY_ONLY_WITH_PREFIX_SLUG_URL }}" == "${{ env.KEY_ONLY_SLUG_URL }}" ]]
[[ "${{ env.CI_KEY_TEST_SLUG_URL_CS }}" == "${{ env.KEY_TEST_SLUG_URL_CS }}" ]] [[ "${{ env.CI_KEY_ONLY_WITH_PREFIX_SLUG_URL_CS }}" == "${{ env.KEY_ONLY_SLUG_URL_CS }}" ]]
shell: bash shell: bash
# Test 3 # Test 3
- name: Slugify key/value - name: Slugify key/value
uses: ./ uses: ./
with: with:
key: KEY_VALUE_TEST key: KEY_VALUE
value: refs/pulls/feat/-----Some----Changes_to.be------ value: "Never gonna give you up Never gonna let you down"
- name: Validate // Slugify key/value - name: Validate // Slugify key/value
run: | run: |
[[ "${{ env.KEY_VALUE_TEST }}" == "refs/pulls/feat/-----Some----Changes_to.be------" ]] [[ "${{ env.KEY_VALUE }}" == "Never gonna give you up Never gonna let you down" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG }}" == "feat-some-changes_to.be" ]] [[ "${{ env.KEY_VALUE_SLUG }}" == "never-gonna-give-you-up-never-gonna-let-you-down" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_CS }}" == "feat-Some-Changes_to.be" ]] [[ "${{ env.KEY_VALUE_SLUG_CS }}" == "Never-gonna-give-you-up-Never-gonna-let-you-down" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_URL }}" == "feat-some-changes_to-be" ]] [[ "${{ env.KEY_VALUE_SLUG_URL }}" == "never-gonna-give-you-up-never-gonna-let-you-down" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_URL_CS }}" == "feat-Some-Changes_to-be" ]] [[ "${{ env.KEY_VALUE_SLUG_URL_CS }}" == "Never-gonna-give-you-up-Never-gonna-let-you-down" ]]
shell: bash shell: bash
# Test 4 # Test 4
- name: Slugify with another max length - name: Slugify with another max length
uses: ./ uses: ./
with: with:
key: KEY_VALUE_TEST key: ANOTHER_MAX_LENGTH
value: refs/pulls/feat/-----Some----Changes_to.be------ value: "Never gonna give you up Never gonna let you down"
slug-maxlength: 12 slug-maxlength: 24
- name: Validate // Slugify with another max length - name: Validate // Slugify with another max length
run: | run: |
[[ "${{ env.KEY_VALUE_TEST }}" == "refs/pulls/feat/-----Some----Changes_to.be------" ]] [[ "${{ env.ANOTHER_MAX_LENGTH }}" == "Never gonna give you up Never gonna let you down" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG }}" == "feat-some-ch" ]] [[ "${{ env.ANOTHER_MAX_LENGTH_SLUG }}" == "never-gonna-give-you-up" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_CS }}" == "feat-Some-Ch" ]] [[ "${{ env.ANOTHER_MAX_LENGTH_SLUG_CS }}" == "Never-gonna-give-you-up" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_URL }}" == "feat-some-ch" ]] [[ "${{ env.ANOTHER_MAX_LENGTH_SLUG_URL }}" == "never-gonna-give-you-up" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_URL_CS }}" == "feat-Some-Ch" ]] [[ "${{ env.ANOTHER_MAX_LENGTH_SLUG_URL_CS }}" == "Never-gonna-give-you-up" ]]
shell: bash shell: bash
# Test 5 # Test 5
- name: Slugify with no limit on max length - name: Slugify with no limit on max length
uses: ./ uses: ./
with: with:
key: KEY_VALUE_TEST key: NO_MAX_LENGTH
value: refs/pulls/feat/-----Some----Changes_to.be-----Some----Changes_to.be-----Some----Changes_to.be-----Some----Changes_to.be------ value: "Never gonna give you up Never gonna let you down Never gonna run around and desert you Never gonna make you cry Never gonna say goodbye Never gonna tell a lie and hurt you"
slug-maxlength: "nolimit" slug-maxlength: "nolimit"
- name: Validate // Slugify with no limit on max length - name: Validate // Slugify with no limit on max length
run: | run: |
[[ "${{ env.KEY_VALUE_TEST }}" == "refs/pulls/feat/-----Some----Changes_to.be-----Some----Changes_to.be-----Some----Changes_to.be-----Some----Changes_to.be------" ]] [[ "${{ env.NO_MAX_LENGTH }}" == "Never gonna give you up Never gonna let you down Never gonna run around and desert you Never gonna make you cry Never gonna say goodbye Never gonna tell a lie and hurt you" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG }}" == "feat-some-changes_to.be-some-changes_to.be-some-changes_to.be-some-changes_to.be" ]] [[ "${{ env.NO_MAX_LENGTH_SLUG }}" == "never-gonna-give-you-up-never-gonna-let-you-down-never-gonna-run-around-and-desert-you-never-gonna-make-you-cry-never-gonna-say-goodbye-never-gonna-tell-a-lie-and-hurt-you" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_CS }}" == "feat-Some-Changes_to.be-Some-Changes_to.be-Some-Changes_to.be-Some-Changes_to.be" ]] [[ "${{ env.NO_MAX_LENGTH_SLUG_CS }}" == "Never-gonna-give-you-up-Never-gonna-let-you-down-Never-gonna-run-around-and-desert-you-Never-gonna-make-you-cry-Never-gonna-say-goodbye-Never-gonna-tell-a-lie-and-hurt-you" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_URL }}" == "feat-some-changes_to-be-some-changes_to-be-some-changes_to-be-some-changes_to-be" ]] [[ "${{ env.NO_MAX_LENGTH_SLUG_URL }}" == "never-gonna-give-you-up-never-gonna-let-you-down-never-gonna-run-around-and-desert-you-never-gonna-make-you-cry-never-gonna-say-goodbye-never-gonna-tell-a-lie-and-hurt-you" ]]
[[ "${{ env.KEY_VALUE_TEST_SLUG_URL_CS }}" == "feat-Some-Changes_to-be-Some-Changes_to-be-Some-Changes_to-be-Some-Changes_to-be" ]] [[ "${{ env.NO_MAX_LENGTH_SLUG_URL_CS }}" == "Never-gonna-give-you-up-Never-gonna-let-you-down-Never-gonna-run-around-and-desert-you-Never-gonna-make-you-cry-Never-gonna-say-goodbye-Never-gonna-tell-a-lie-and-hurt-you" ]]
shell: bash shell: bash
# Test 6 # Test 6
@@ -135,6 +141,29 @@ jobs:
[[ "${{ steps.slugify-with-wrong-max-length.conclusion }}" == "success" ]] [[ "${{ steps.slugify-with-wrong-max-length.conclusion }}" == "success" ]]
shell: bash shell: bash
# Test 8
- name: Slugify key without env publication
id: slugify-key-without-env-publication
uses: ./
with:
key: KEY_WITHOUT_ENV_PUBLICATION
publish-env: false
env:
KEY_WITHOUT_ENV_PUBLICATION: "Never gonna give you up"
- name: Validate // Slugify key without env publication
run: |
[[ -z "${{ env.KEY_WITHOUT_ENV_PUBLICATION }}" ]]
[[ -z "${{ env.KEY_WITHOUT_ENV_PUBLICATION_SLUG }}" ]]
[[ -z "${{ env.KEY_WITHOUT_ENV_PUBLICATION_SLUG_CS }}" ]]
[[ -z "${{ env.KEY_WITHOUT_ENV_PUBLICATION_SLUG_URL }}" ]]
[[ -z "${{ env.KEY_WITHOUT_ENV_PUBLICATION_SLUG_URL_CS }}" ]]
[[ "${{ steps.slugify-key-without-env-publication.outputs.value }}" == "Never gonna give you up" ]]
[[ "${{ steps.slugify-key-without-env-publication.outputs.slug }}" == "never-gonna-give-you-up" ]]
[[ "${{ steps.slugify-key-without-env-publication.outputs.slug-cs }}" == "Never-gonna-give-you-up" ]]
[[ "${{ steps.slugify-key-without-env-publication.outputs.slug-url }}" == "never-gonna-give-you-up" ]]
[[ "${{ steps.slugify-key-without-env-publication.outputs.slug-url-cs }}" == "Never-gonna-give-you-up" ]]
shell: bash
release: release:
runs-on: ubuntu-latest runs-on: ubuntu-latest
concurrency: concurrency:

View File

@@ -8,8 +8,9 @@ Produce some `slug`-ed environment variables based on the input one.
- put the variable content in lower case - put the variable content in lower case
- replace any character by `-` except `0-9`, `a-z`, `.`, and `_` - replace any character by `-` except `0-9`, `a-z`, `.`, and `_`
- remove leading and trailing `-` character - remove leading `-` character
- limit the string size to 63 characters - limit the string size to 63 characters
- remove trailing `-` character
- `<env name>_SLUG_CS` - `<env name>_SLUG_CS`
@@ -17,7 +18,7 @@ Produce some `slug`-ed environment variables based on the input one.
- `<env name>_SLUG_URL` (or `<env name>_SLUG_URL_CS`) - `<env name>_SLUG_URL` (or `<env name>_SLUG_URL_CS`)
- like `<env name>_SLUG` (or `<env name>_SLUG_CS`) with the `.` character also replaced by `-` - like `<env name>_SLUG` (or `<env name>_SLUG_CS`) with the `.`, and `_` characters also replaced by `-`
## Usage ## Usage
@@ -81,7 +82,7 @@ Produce some `slug`-ed environment variables based on the input one.
Will produce SLUG variables with a 80-char length Will produce SLUG variables with a 80-char length
- Slugify a value without - Slugify a value without length limit
```yaml ```yaml
- uses: rlespinasse/slugify-value@v1.x - uses: rlespinasse/slugify-value@v1.x
@@ -92,28 +93,39 @@ Produce some `slug`-ed environment variables based on the input one.
Will produce SLUG variables without limiting the output length Will produce SLUG variables without limiting the output length
- Slugify a value without publishing the environment variables
```yaml
- uses: rlespinasse/slugify-value@v1.x
with:
key: KEY_NAME
value: value_to_slugify
```
Will **not** make available
- `KEY_NAME`
- `KEY_NAME_SLUG`
- `KEY_NAME_SLUG_CS`
- `KEY_NAME_SLUG_URL`
- `KEY_NAME_SLUG_URL_CS`
## Inputs ## Inputs
### `key` | Input | Description | Mandatory | Default |
| -------------- | ----------------------------------------------------------------------------------------------------- | --------- | ------- |
| key | Environment variable that will hold the value and serve as prefix to slugified value | Yes | |
| value | The value to slugify. If not set the value will be taken from the `key` input as environment variable | No | |
| prefix | The value will be prepend to each generated variable | No | |
| slug-maxlength | The value is a number or `nolimit` to reflect the length of the slug outputs | No | 63 |
| publish-env | In addition of the action output, the slug values are publish as environment variables | No | true |
Environment variable that will hold the value and serve as prefix to slugified value. ## Outputs
This input is _Mandatory_. | Output | Description |
| ----------- | ------------------------------- |
### `value` | value | The value to be slugify |
| slug | Value Slug |
The value to slugify. If not set the value will be taken from the `key` input as environment variable. | slug-cs | Value Slug (Case-sensitive) |
| slug-url | Value Slug URL |
This input is _Optional_. | slug-url-cs | Value Slug URL (Case-sensitive) |
### `prefix`
The value will be prepend to each generated variable.
This input is _Optional_.
### `slug-maxlength`
The value is a number or `nolimit` to reflect the length of the slug outputs
This input is _Optional_. The default value is `63`.

View File

@@ -1,6 +1,9 @@
name: "Slugify Value" name: "Slugify Value"
description: "Github Action to slugify a value" description: "Github Action to slugify a value"
author: "Romain Lespinasse" author: "Romain Lespinasse"
branding:
icon: "crop"
color: "gray-dark"
inputs: inputs:
key: key:
description: "Environment variable that will hold the value and serve as prefix to slugified value" description: "Environment variable that will hold the value and serve as prefix to slugified value"
@@ -16,16 +19,35 @@ inputs:
description: "Max length of the slugified values" description: "Max length of the slugified values"
default: "63" default: "63"
required: true required: true
branding: publish-env:
icon: "crop" description: "Publish slugs as environment variables"
color: "gray-dark" default: "true"
required: true
outputs:
value:
description: "The value to be slugify"
value: ${{ steps.slugify.outputs.value }}
slug:
description: "Value Slug"
value: ${{ steps.slugify.outputs.slug }}
slug-cs:
description: "Value Slug (Case-sensitive)"
value: ${{ steps.slugify.outputs.slug-cs }}
slug-url:
description: "Value Slug URL"
value: ${{ steps.slugify.outputs.slug-url }}
slug-url-cs:
description: "Value Slug URL (Case-sensitive)"
value: ${{ steps.slugify.outputs.slug-url-cs }}
runs: runs:
using: "composite" using: "composite"
steps: steps:
- run: $GITHUB_ACTION_PATH/slugify.sh - id: slugify
run: $GITHUB_ACTION_PATH/slugify.sh
shell: bash shell: bash
env: env:
INPUT_KEY: ${{ inputs.key }} INPUT_KEY: ${{ inputs.key }}
INPUT_VALUE: ${{ inputs.value }} INPUT_VALUE: ${{ inputs.value }}
INPUT_PREFIX: ${{ inputs.prefix }} INPUT_PREFIX: ${{ inputs.prefix }}
INPUT_SLUG_MAXLENGTH: ${{ inputs.slug-maxlength }} INPUT_SLUG_MAXLENGTH: ${{ inputs.slug-maxlength }}
INPUT_PUBLISH_ENV: ${{ inputs.publish-env }}

View File

@@ -28,27 +28,57 @@ else
fi fi
slug() { slug() {
output=$(sed -E 's#refs/[^\/]*/##;s/[^a-zA-Z0-9._-]+/-/g;s/-+/-/g;s/^-*//;s/-*$//' <<<"$1") # 1st : Remove refs prefix
# 2d : Replace unwanted characters
# 3d : Remove leading hypens
output=$(sed -E 's#refs/[^\/]*/##;s/[^a-zA-Z0-9._-]+/-/g;s/^-*//' <<<"$1")
reduce "$output" reduce "$output"
} }
slug_url() { slug_url() {
output=$(sed -E 's#refs/[^\/]*/##;s/[^a-zA-Z0-9_-]+/-/g;s/-+/-/g;s/^-*//;s/-*$//' <<<"$1") # 1st : Remove refs prefix
# 2d : Replace unwanted characters
# 3d : Remove leading hypens
output=$(sed -E 's#refs/[^\/]*/##;s/[^a-zA-Z0-9-]+/-/g;s/^-*//' <<<"$1")
reduce "$output" reduce "$output"
} }
reduce() { reduce() {
if [ "${MAX_LENGTH}" == "nolimit" ]; then reduced_value="$1"
echo "$1" if [ "${MAX_LENGTH}" != "nolimit" ]; then
else reduced_value=$(cut -c1-"${MAX_LENGTH}" <<<"$reduced_value")
cut -c1-"${MAX_LENGTH}" <<<"$1"
fi fi
# 1st : Remove trailing hypens
sed -E 's/-*$//' <<<"$reduced_value"
} }
{ SLUG_VALUE=$(slug "$VALUE")
echo "${PREFIX}${KEY}=${CS_VALUE}" SLUG_CS_VALUE=$(slug "$CS_VALUE")
echo "${PREFIX}${KEY}_SLUG=$(slug "$VALUE")" SLUG_URL_VALUE=$(slug_url "$VALUE")
echo "${PREFIX}${KEY}_SLUG_CS=$(slug "$CS_VALUE")" SLUG_URL_CS_VALUE=$(slug_url "$CS_VALUE")
echo "${PREFIX}${KEY}_SLUG_URL=$(slug_url "$VALUE")"
echo "${PREFIX}${KEY}_SLUG_URL_CS=$(slug_url "$CS_VALUE")" if [ -f "$GITHUB_OUTPUT" ]; then
} >>"$GITHUB_ENV" {
echo "value=${CS_VALUE}"
echo "slug=${SLUG_VALUE}"
echo "slug-cs=${SLUG_CS_VALUE}"
echo "slug-url=${SLUG_URL_VALUE}"
echo "slug-url-cs=${SLUG_URL_CS_VALUE}"
} >> "$GITHUB_OUTPUT"
else
echo "::set-output name=value::${CS_VALUE}"
echo "::set-output name=slug::${SLUG_VALUE}"
echo "::set-output name=slug-cs::${SLUG_CS_VALUE}"
echo "::set-output name=slug-url::${SLUG_URL_VALUE}"
echo "::set-output name=slug-url-cs::${SLUG_URL_CS_VALUE}"
fi
if [ "${INPUT_PUBLISH_ENV}" == "true" ]; then
{
echo "${PREFIX}${KEY}=${CS_VALUE}"
echo "${PREFIX}${KEY}_SLUG=${SLUG_VALUE}"
echo "${PREFIX}${KEY}_SLUG_CS=${SLUG_CS_VALUE}"
echo "${PREFIX}${KEY}_SLUG_URL=${SLUG_URL_VALUE}"
echo "${PREFIX}${KEY}_SLUG_URL_CS=${SLUG_URL_CS_VALUE}"
} >>"$GITHUB_ENV"
fi