|
|
|
@ -3,6 +3,8 @@ on:
|
|
|
|
|
push:
|
|
|
|
|
branches:
|
|
|
|
|
- master
|
|
|
|
|
tags:
|
|
|
|
|
- 'v*'
|
|
|
|
|
pull_request_target:
|
|
|
|
|
|
|
|
|
|
permissions: {}
|
|
|
|
@ -14,7 +16,7 @@ jobs:
|
|
|
|
|
permissions: read-all
|
|
|
|
|
steps:
|
|
|
|
|
- name: Checkout repository
|
|
|
|
|
uses: actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
|
|
|
|
|
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
|
|
|
|
|
with:
|
|
|
|
|
ref: ${{ github.event.pull_request.head.sha }}
|
|
|
|
|
repository: ${{ github.event.pull_request.head.repo.full_name }}
|
|
|
|
@ -39,7 +41,7 @@ jobs:
|
|
|
|
|
permissions: read-all
|
|
|
|
|
steps:
|
|
|
|
|
- name: Checkout repository
|
|
|
|
|
uses: actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
|
|
|
|
|
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
|
|
|
|
|
with:
|
|
|
|
|
ref: ${{ github.event.pull_request.head.sha }}
|
|
|
|
|
repository: ${{ github.event.pull_request.head.repo.full_name }}
|
|
|
|
@ -99,11 +101,24 @@ jobs:
|
|
|
|
|
- id: read-diff
|
|
|
|
|
name: Read openapi-diff output
|
|
|
|
|
run: |
|
|
|
|
|
# Read and fix markdown
|
|
|
|
|
body=$(cat openapi-changes.md)
|
|
|
|
|
body="${body//'%'/'%25'}"
|
|
|
|
|
body="${body//$'\n'/'%0A'}"
|
|
|
|
|
body="${body//$'\r'/'%0D'}"
|
|
|
|
|
echo ::set-output name=body::$body
|
|
|
|
|
# Write to workflow summary
|
|
|
|
|
echo "$body" >> $GITHUB_STEP_SUMMARY
|
|
|
|
|
# Set ApiChanged var
|
|
|
|
|
if [ "$body" != '' ]; then
|
|
|
|
|
echo "ApiChanged=1" >> "$GITHUB_OUTPUT"
|
|
|
|
|
else
|
|
|
|
|
echo "ApiChanged=0" >> "$GITHUB_OUTPUT"
|
|
|
|
|
fi
|
|
|
|
|
# Add header/footer for diff comment
|
|
|
|
|
echo '<!--openapi-diff-workflow-comment-->' > openapi-changes-reply.md
|
|
|
|
|
echo "<details>" >> openapi-changes-reply.md
|
|
|
|
|
echo "<summary>Changes in OpenAPI specification found. Expand to see details.</summary>" >> openapi-changes-reply.md
|
|
|
|
|
echo "" >> openapi-changes-reply.md
|
|
|
|
|
echo "$body" >> openapi-changes-reply.md
|
|
|
|
|
echo "" >> openapi-changes-reply.md
|
|
|
|
|
echo "</details>" >> openapi-changes-reply.md
|
|
|
|
|
- name: Find difference comment
|
|
|
|
|
uses: peter-evans/find-comment@3eae4d37986fb5a8592848f6a574fdf654e61f9e # v3.1.0
|
|
|
|
|
id: find-comment
|
|
|
|
@ -113,22 +128,15 @@ jobs:
|
|
|
|
|
body-includes: openapi-diff-workflow-comment
|
|
|
|
|
- name: Reply or edit difference comment (changed)
|
|
|
|
|
uses: peter-evans/create-or-update-comment@71345be0265236311c031f5c7866368bd1eff043 # v4.0.0
|
|
|
|
|
if: ${{ steps.read-diff.outputs.body != '' }}
|
|
|
|
|
if: ${{ steps.read-diff.outputs.ApiChanged == '1' }}
|
|
|
|
|
with:
|
|
|
|
|
issue-number: ${{ github.event.pull_request.number }}
|
|
|
|
|
comment-id: ${{ steps.find-comment.outputs.comment-id }}
|
|
|
|
|
edit-mode: replace
|
|
|
|
|
body: |
|
|
|
|
|
<!--openapi-diff-workflow-comment-->
|
|
|
|
|
<details>
|
|
|
|
|
<summary>Changes in OpenAPI specification found. Expand to see details.</summary>
|
|
|
|
|
|
|
|
|
|
${{ steps.read-diff.outputs.body }}
|
|
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
body-path: openapi-changes-reply.md
|
|
|
|
|
- name: Edit difference comment (unchanged)
|
|
|
|
|
uses: peter-evans/create-or-update-comment@71345be0265236311c031f5c7866368bd1eff043 # v4.0.0
|
|
|
|
|
if: ${{ steps.read-diff.outputs.body == '' && steps.find-comment.outputs.comment-id != '' }}
|
|
|
|
|
if: ${{ steps.read-diff.outputs.ApiChanged == '0' && steps.find-comment.outputs.comment-id != '' }}
|
|
|
|
|
with:
|
|
|
|
|
issue-number: ${{ github.event.pull_request.number }}
|
|
|
|
|
comment-id: ${{ steps.find-comment.outputs.comment-id }}
|
|
|
|
@ -138,11 +146,9 @@ jobs:
|
|
|
|
|
|
|
|
|
|
No changes to OpenAPI specification found. See history of this comment for previous changes.
|
|
|
|
|
|
|
|
|
|
publish:
|
|
|
|
|
publish-unstable:
|
|
|
|
|
name: OpenAPI - Publish Unstable Spec
|
|
|
|
|
if: |
|
|
|
|
|
github.event_name != 'pull_request_target' &&
|
|
|
|
|
contains(github.repository_owner, 'jellyfin')
|
|
|
|
|
if: ${{ github.event_name != 'pull_request_target' && !startsWith(github.ref, 'refs/tags/v') && contains(github.repository_owner, 'jellyfin') }}
|
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
needs:
|
|
|
|
|
- openapi-head
|
|
|
|
@ -201,3 +207,65 @@ jobs:
|
|
|
|
|
sudo ln -s unstable/${LAST_SPEC} ${TGT_DIR}/jellyfin-openapi-unstable_previous.json
|
|
|
|
|
fi
|
|
|
|
|
) 200>/run/workflows/openapi-unstable.lock
|
|
|
|
|
|
|
|
|
|
publish-stable:
|
|
|
|
|
name: OpenAPI - Publish Stable Spec
|
|
|
|
|
if: ${{ startsWith(github.ref, 'refs/tags/v') && contains(github.repository_owner, 'jellyfin') }}
|
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
needs:
|
|
|
|
|
- openapi-head
|
|
|
|
|
steps:
|
|
|
|
|
- name: Set version number
|
|
|
|
|
id: version
|
|
|
|
|
run: |-
|
|
|
|
|
echo "JELLYFIN_VERSION=${GITHUB_REF#refs/tags/v}" >> $GITHUB_ENV
|
|
|
|
|
- name: Download openapi-head
|
|
|
|
|
uses: actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # v4.1.7
|
|
|
|
|
with:
|
|
|
|
|
name: openapi-head
|
|
|
|
|
path: openapi-head
|
|
|
|
|
- name: Upload openapi.json (stable) to repository server
|
|
|
|
|
uses: appleboy/scp-action@917f8b81dfc1ccd331fef9e2d61bdc6c8be94634 # v0.1.7
|
|
|
|
|
with:
|
|
|
|
|
host: "${{ secrets.REPO_HOST }}"
|
|
|
|
|
username: "${{ secrets.REPO_USER }}"
|
|
|
|
|
key: "${{ secrets.REPO_KEY }}"
|
|
|
|
|
source: openapi-head/openapi.json
|
|
|
|
|
strip_components: 1
|
|
|
|
|
target: "/srv/incoming/openapi/stable/jellyfin-openapi-${{ env.JELLYFIN_VERSION }}"
|
|
|
|
|
- name: Move openapi.json (stable) into place
|
|
|
|
|
uses: appleboy/ssh-action@029f5b4aeeeb58fdfe1410a5d17f967dacf36262 # v1.0.3
|
|
|
|
|
with:
|
|
|
|
|
host: "${{ secrets.REPO_HOST }}"
|
|
|
|
|
username: "${{ secrets.REPO_USER }}"
|
|
|
|
|
key: "${{ secrets.REPO_KEY }}"
|
|
|
|
|
debug: false
|
|
|
|
|
script_stop: false
|
|
|
|
|
script: |
|
|
|
|
|
if ! test -d /run/workflows; then
|
|
|
|
|
sudo mkdir -p /run/workflows
|
|
|
|
|
sudo chown ${{ secrets.REPO_USER }} /run/workflows
|
|
|
|
|
fi
|
|
|
|
|
(
|
|
|
|
|
flock -x -w 300 200 || exit 1
|
|
|
|
|
TGT_DIR="/srv/repository/main/openapi"
|
|
|
|
|
LAST_SPEC="$( ls -lt ${TGT_DIR}/stable/ | grep 'jellyfin-openapi' | head -1 | awk '{ print $NF }' )"
|
|
|
|
|
# If new and previous spec don't differ (diff retcode 0), remove incoming and finish
|
|
|
|
|
if diff /srv/incoming/openapi/stable/jellyfin-openapi-${{ env.JELLYFIN_VERSION }}/openapi.json ${TGT_DIR}/stable/${LAST_SPEC} &>/dev/null; then
|
|
|
|
|
rm -r /srv/incoming/openapi/stable/jellyfin-openapi-${{ env.JELLYFIN_VERSION }}
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
|
|
|
|
# Move new spec into place
|
|
|
|
|
sudo mv /srv/incoming/openapi/stable/jellyfin-openapi-${{ env.JELLYFIN_VERSION }}/openapi.json ${TGT_DIR}/stable/jellyfin-openapi-${{ env.JELLYFIN_VERSION }}.json
|
|
|
|
|
# Delete previous jellyfin-openapi-stable_previous.json
|
|
|
|
|
sudo rm ${TGT_DIR}/jellyfin-openapi-stable_previous.json
|
|
|
|
|
# Move current jellyfin-openapi-stable.json symlink to jellyfin-openapi-stable_previous.json
|
|
|
|
|
sudo mv ${TGT_DIR}/jellyfin-openapi-stable.json ${TGT_DIR}/jellyfin-openapi-stable_previous.json
|
|
|
|
|
# Create new jellyfin-openapi-stable.json symlink
|
|
|
|
|
sudo ln -s stable/jellyfin-openapi-${{ env.JELLYFIN_VERSION }}.json ${TGT_DIR}/jellyfin-openapi-stable.json
|
|
|
|
|
# Check that the previous openapi stable spec link is correct
|
|
|
|
|
if [[ "$( readlink ${TGT_DIR}/jellyfin-openapi-stable_previous.json )" != "stable/${LAST_SPEC}" ]]; then
|
|
|
|
|
sudo rm ${TGT_DIR}/jellyfin-openapi-stable_previous.json
|
|
|
|
|
sudo ln -s stable/${LAST_SPEC} ${TGT_DIR}/jellyfin-openapi-stable_previous.json
|
|
|
|
|
fi
|
|
|
|
|
) 200>/run/workflows/openapi-stable.lock
|
|
|
|
|