Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/snsinahub/calver-release

Create release tags based on calendar versioning
https://github.com/snsinahub/calver-release

actions apache apache-lucene calver github-actions github-workflow open-source opensource

Last synced: 3 days ago
JSON representation

Create release tags based on calendar versioning

Awesome Lists containing this project

README

        

# calver-release

## Introduction

Calver release is an action that dynamically generates github `release tags` based on calnder versioning. The generated tag is a combination of `today's date` based on date format passed to the action and an `incremental digit` which indicates release number for the specified day.

For instance if date format is `YYYYMMD` and today is 08/22/2022, then the first and second releases of the day will be
- 2022082.1
- 2022082.2

## Formating Date
This action uses moment.js and JS date format, here is few examples of supported date formats tokens

- YYYY: 4-digit year '2022'
- YY: 2-digit year '22'
- MMMM: Full-length month 'August'
- MMM: 3 character month 'Aug'
- MM: Month of the year, zero-padded '08'
- M: Month of the year '22'
- DD: Day of the month, zero-padded '22'
- D: Day of the month '22'
- Do: Day of the month with numeric ordinal contraction '22nd'
- HH: hour

### Date formats Examples
you can separate year, month and day by `.`, `-` and more
- YYYYMMD: `20220822`
- YYYY-MM-D: `2022-08-22`
- YYYY.MM.D: `2022.08.22`

## Inputs
```YAML
- uses: snsinahub/[email protected]
with:
# Repository name
# default: ${{ github.repository }}
# required: false
repo: ''

# Token to access to the repository
# GITHUB_TOKEN can be used to access to the same repository
# If you'd like to access to another repository you can use either PAT(Personal Access Token) Or use a service account
# Using Service Account with least permissions is recommended
# default: ${{ github.token }}
# required: false
token:

# Release tag date format
# default: YYYYMMD
# required: false
date_format:

# Local timezone
# default: America/New_York
# required: false
time_zone:

# required: false
# default: ''
tag_prepend:

# required: false
# default: ''
tag_append:

# required: false
# default: '.'
append_prepend_separator:

```

## Output
| Name | Description |
| -- | -- |
| newTag | Get latest release tag and increment the iteration by 1 |

## Examples

### Use default values

```YAML
- name: checkout
uses: actions/checkout@v2
- name: get a new tag
id: tag-generator
uses: snsinahub/[email protected]
- name: print new tag
run: |
echo ${{ steps.tag-generator.outputs.newTag }}
```

## Passing Date format

```YAML
- name: checkout
uses: actions/checkout@v2
- name: get a new tag
id: tag-generator
uses: snsinahub/[email protected]
with:
repo: "${{ github.repository }}"
token: "${{ secrets.GITHUB_TOKEN }}"
date_format: "YYYYMMD"
- name: print new tag
run: |
echo ${{ steps.tag-generator.outputs.newTag }}
```

## Passing Date format and timezone

```YAML
- name: checkout
uses: actions/checkout@v2
- name: get a new tag
id: tag-generator
uses: snsinahub/[email protected]
with:
repo: "${{ github.repository }}"
token: "${{ secrets.GITHUB_TOKEN }}"
date_format: "YYYY-MM-D"
time_zone: "America/New_York"
- name: print new tag
run: |
echo ${{ steps.tag-generator.outputs.newTag }}
```

## Adding prefix
```YAML
- name: get a new tag
id: tag-generator
uses: snsinahub/[email protected]
with:
date_format: "${{ github.event.inputs.date_format }}"
tag_prepend: ${{ github.event.inputs.tag_prepend }}
append_prepend_separator: ${{ github.event.inputs.append_prepend_separator }}
```

## Adding postfix
```YAML
- name: get a new tag
id: tag-generator
uses: snsinahub/[email protected]
with:
date_format: "${{ github.event.inputs.date_format }}"
tag_append: ${{ github.event.inputs.tag_append }}
append_prepend_separator: ${{ github.event.inputs.append_prepend_separator }}
```

## Adding both prefix and postfix
```YAML
- name: get a new tag
id: tag-generator
uses: snsinahub/[email protected]
with:
date_format: "${{ github.event.inputs.date_format }}"
tag_prepend: ${{ github.event.inputs.tag_prepend }}
tag_append: ${{ github.event.inputs.tag_append }}
append_prepend_separator: ${{ github.event.inputs.append_prepend_separator }}
```

## External References
- [Formatting JavaScript Dates with Moment.js](https://thecodebarbarian.com/formatting-javascript-dates-with-moment-js.html)
- [Moment.js](https://momentjs.com/)