Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ Name | Description | Example
repository | The Github owner/repository | `nodejs/node`
type | The release type (prerelease | stable | latest | nodraft) | `stable`
token | Github auth token (default variable for each action session) | `${{ secrets.GITHUB_TOKEN }}`
filter | A regex, filtering out releases that do not match | `^.*(?<!\+alpha)$`

#### Possible values for `type` input
* *stable* - Get the stable `latest` release
Expand Down
4 changes: 4 additions & 0 deletions action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,10 @@ inputs:
type:
description: 'Wanted release type (latest, stable, draft, nodraft)'
required: true
filter:
description: 'A regex, filtering out releases that do not match'
required: false
type: string

outputs:
release:
Expand Down
9 changes: 9 additions & 0 deletions entrypoint.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,18 @@

from github import Github
import os
import re

# Try to get options from enviroment and from inputs as fallback
wanted_release = os.getenv('type', os.getenv('INPUT_TYPE'))
repository = os.getenv('repository', os.getenv('INPUT_REPOSITORY'))
token = os.getenv('token', os.getenv('INPUT_TOKEN', None))

filter = os.getenv('filter', os.getenv('INPUT_FILTER', None))
filter_regex = None
if filter:
filter_regex = re.compile(filter)

# Init class
G = Github(token) if token else Github()
repo = G.get_repo(repository)
Expand All @@ -25,6 +31,9 @@ def output(release):

# Releases parsing
for release in releases:
if filter_regex is not None and re.search(filter_regex, release.tag_name) is None:
continue

if wanted_release == 'stable':
if release.prerelease == 0 and release.draft == 0:
output(release)
Expand Down