mirror of
https://code.forgejo.org/actions/forgejo-release.git
synced 2025-11-28 02:01:58 +02:00
feat: release notes from file
Takes priority over `release-notes`. Most useful in cases where we need to generate something from a script; for example, if you have like 80 different assets and autogenerate a table to make it easier for users to select their platform/sums/etc Signed-off-by: crueter <crueter@eden-emu.dev>
This commit is contained in:
parent
e5e095057a
commit
05d41bd915
2 changed files with 35 additions and 0 deletions
22
README.md
22
README.md
|
|
@ -18,6 +18,7 @@ Upload or download the assets of a release to a Forgejo instance.
|
||||||
| `token` | <p>Forgejo application token</p> | `false` | `${{ secrets.GITHUB_TOKEN }}` |
|
| `token` | <p>Forgejo application token</p> | `false` | `${{ secrets.GITHUB_TOKEN }}` |
|
||||||
| `release-dir` | <p>Directory in whichs release assets are uploaded or downloaded</p> | `true` | `""` |
|
| `release-dir` | <p>Directory in whichs release assets are uploaded or downloaded</p> | `true` | `""` |
|
||||||
| `release-notes` | <p>Release notes</p> | `false` | `""` |
|
| `release-notes` | <p>Release notes</p> | `false` | `""` |
|
||||||
|
| `release-notes-file` | <p>Path to a file containing your release notes (takes priority over `release-notes`)</p> | `false` | `""` |
|
||||||
| `direction` | <p>Can either be <code>download</code> or <code>upload</code></p> | `true` | `""` |
|
| `direction` | <p>Can either be <code>download</code> or <code>upload</code></p> | `true` | `""` |
|
||||||
| `gpg-private-key` | <p>GPG Private Key to sign the release artifacts</p> | `false` | `""` |
|
| `gpg-private-key` | <p>GPG Private Key to sign the release artifacts</p> | `false` | `""` |
|
||||||
| `gpg-passphrase` | <p>Passphrase of the GPG Private Key</p> | `false` | `""` |
|
| `gpg-passphrase` | <p>Passphrase of the GPG Private Key</p> | `false` | `""` |
|
||||||
|
|
@ -53,6 +54,27 @@ jobs:
|
||||||
release-notes: "MY RELEASE NOTES"
|
release-notes: "MY RELEASE NOTES"
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Upload a release with custom release notes located in a file:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
jobs:
|
||||||
|
upload-release:
|
||||||
|
runs-on: docker
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Generate Changelog
|
||||||
|
run: ./generate-changelog.sh > dist/changelog.md
|
||||||
|
- uses: actions/forgejo-release@v2.7.3
|
||||||
|
with:
|
||||||
|
direction: upload
|
||||||
|
url: https://my-forgejo-instance.net
|
||||||
|
repo: myuser/myrepo
|
||||||
|
token: ${{ secrets.WRITE_TOKEN_TO_MYREPO }}
|
||||||
|
tag: v13.0.2
|
||||||
|
release-dir: dist/release
|
||||||
|
release-notes-file: dist/changelog.md
|
||||||
|
```
|
||||||
|
|
||||||
### Download
|
### Download
|
||||||
|
|
||||||
Example downloading the forgejo release v1.21.4-0 into the working directory:
|
Example downloading the forgejo release v1.21.4-0 into the working directory:
|
||||||
|
|
|
||||||
13
action.yml
13
action.yml
|
|
@ -26,6 +26,9 @@ inputs:
|
||||||
required: true
|
required: true
|
||||||
release-notes:
|
release-notes:
|
||||||
description: 'Release notes'
|
description: 'Release notes'
|
||||||
|
release-notes-file:
|
||||||
|
description: 'Path to a file containing your release notes (takes priority over release-notes)'
|
||||||
|
required: false
|
||||||
direction:
|
direction:
|
||||||
description: 'Can either be `download` or `upload`'
|
description: 'Can either be `download` or `upload`'
|
||||||
required: true
|
required: true
|
||||||
|
|
@ -97,6 +100,16 @@ runs:
|
||||||
EOF
|
EOF
|
||||||
)
|
)
|
||||||
|
|
||||||
|
RELEASENOTES_FILE="${{ inputs.release-notes-file }}"
|
||||||
|
if [ ! -z "$RELEASENOTES_FILE" ]; then
|
||||||
|
if [ ! -f "$RELEASENOTES_FILE" ]; then
|
||||||
|
echo "! Release notes file $RELEASENOTES_FILE does not exist."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
export RELEASENOTES=$(cat "$RELEASENOTES_FILE")
|
||||||
|
fi
|
||||||
|
|
||||||
export SHA="${{ inputs.sha }}"
|
export SHA="${{ inputs.sha }}"
|
||||||
|
|
||||||
export OVERRIDE="${{ inputs.override }}"
|
export OVERRIDE="${{ inputs.override }}"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue