shadow-tls #870
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: "shadow-tls" | |
on: | |
repository_dispatch: | |
workflow_dispatch: | |
inputs: | |
ssh: | |
description: 'SSH connection to Actions' | |
required: false | |
default: 'false' | |
schedule: | |
- cron: "0 */8 * * *" | |
env: | |
TZ: Asia/Shanghai | |
jobs: | |
job_init: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@main | |
- name: Initialization environment | |
run: | | |
sudo timedatectl set-timezone "$TZ" | |
- name: Delete workflow runs | |
uses: Mattraks/delete-workflow-runs@main | |
with: | |
token: ${{ github.token }} | |
repository: ${{ github.repository }} | |
retain_days: 1 | |
keep_minimum_runs: 1 | |
- name: SSH connection to Actions | |
uses: kenzok78/ssh-action@master | |
if: (github.event.inputs.ssh == 'true' && github.event.inputs.ssh != 'false') || contains(github.event.action, 'ssh') | |
job_auto_update_packages: | |
if: ${{ always() }} | |
needs: job_init | |
runs-on: ubuntu-latest | |
name: update-${{ matrix.pakcages }} | |
strategy: | |
fail-fast: false | |
matrix: | |
pakcages: [shadow-tls] | |
include: | |
- pakcages: shadow-tls-aarch64 | |
folder: shadow-tls | |
version_head: PKG_VERSION:= | |
hash_head: \ PKG_HASH:= | |
version_line: | |
hash_line: 14 | |
release_api_command: curl -sL "https://api.github.com/repos/ihciah/shadow-tls/releases" | jq -r 'map(select(.prerelease|not)) | first | .tag_name' | sed -e 's/.*v//' | |
release_download_url: https://github.com/ihciah/shadow-tls/releases/download/v | |
file_name: /shadow-tls-aarch64-unknown-linux-musl | |
- pakcages: shadow-tls-armv7-musleabihf | |
folder: shadow-tls | |
version_head: PKG_VERSION:= | |
hash_head: \ PKG_HASH:= | |
version_line: | |
hash_line: 18 | |
release_api_command: curl -sL "https://api.github.com/repos/ihciah/shadow-tls/releases" | jq -r 'map(select(.prerelease|not)) | first | .tag_name' | sed -e 's/.*v//' | |
release_download_url: https://github.com/ihciah/shadow-tls/releases/download/v | |
file_name: /shadow-tls-armv7-unknown-linux-musleabihf | |
- pakcages: shadow-tls-armv7-musleabihf | |
folder: shadow-tls | |
version_head: PKG_VERSION:= | |
hash_head: \ PKG_HASH:= | |
version_line: | |
hash_line: 21 | |
release_api_command: curl -sL "https://api.github.com/repos/ihciah/shadow-tls/releases" | jq -r 'map(select(.prerelease|not)) | first | .tag_name' | sed -e 's/.*v//' | |
release_download_url: https://github.com/ihciah/shadow-tls/releases/download/v | |
file_name: /shadow-tls-armv7-unknown-linux-musleabihf | |
- pakcages: shadow-tls-arm-musleabi | |
folder: shadow-tls | |
version_head: PKG_VERSION:= | |
hash_head: \ PKG_HASH:= | |
version_line: | |
hash_line: 24 | |
release_api_command: curl -sL "https://api.github.com/repos/ihciah/shadow-tls/releases" | jq -r 'map(select(.prerelease|not)) | first | .tag_name' | sed -e 's/.*v//' | |
release_download_url: https://github.com/ihciah/shadow-tls/releases/download/v | |
file_name: /shadow-tls-arm-unknown-linux-musleabi | |
- pakcages: shadow-tls-x86_64 | |
folder: shadow-tls | |
version_head: PKG_VERSION:= | |
hash_head: \ PKG_HASH:= | |
version_line: | |
hash_line: 28 | |
release_api_command: curl -sL "https://api.github.com/repos/ihciah/shadow-tls/releases" | jq -r 'map(select(.prerelease|not)) | first | .tag_name' | sed -e 's/.*v//' | |
release_download_url: https://github.com/ihciah/shadow-tls/releases/download/v | |
file_name: /shadow-tls-x86_64-unknown-linux-musl | |
steps: | |
- name: Checkout | |
uses: actions/checkout@main | |
- name: Initialization environment | |
run: | | |
cd && mkdir -p pack && cd pack | |
sudo timedatectl set-timezone "$TZ" | |
- name: Check ${{ matrix.pakcages }} | |
id: check | |
run: | | |
is_continue=true | |
if [ "$is_continue" = "true" ]; then | |
cd && cd $GITHUB_WORKSPACE/${{ matrix.folder }} | |
if [ ! -n "${{ matrix.version_line }}" ] ; then | |
Old_PKG_VERSION=$(sed -n '/^${{ matrix.version_head }}/p' Makefile | awk -F '=' '{print $2}'); | |
else | |
Old_PKG_VERSION=$(sed -n '${{ matrix.version_line }}p' Makefile | awk -F '=' '{print $2}'); | |
fi | |
New_PKG_VERSION=$(${{ matrix.release_api_command }}) | |
echo "${{ matrix.pakcages }}目前版本: $Old_PKG_VERSION" | |
echo "${{ matrix.pakcages }}最新版本: $New_PKG_VERSION" | |
if [ "$Old_PKG_VERSION" = "$New_PKG_VERSION" ]; then | |
echo "status=failure" >> $GITHUB_OUTPUT; | |
echo "${{ matrix.pakcages }}版本为最新版本$New_PKG_VERSION,无需更新"; | |
else | |
echo "New_PKG_VERSION=$New_PKG_VERSION" >> $GITHUB_OUTPUT; | |
echo "status=success" >> $GITHUB_OUTPUT; | |
fi | |
else | |
echo "status=failure" >> $GITHUB_OUTPUT; | |
fi | |
- name: Update ${{ matrix.pakcages }} | |
id: update | |
if: steps.check.outputs.status == 'success' && steps.check.outputs.New_PKG_VERSION != '' && !cancelled() | |
run: | | |
cd && cd $GITHUB_WORKSPACE/${{ matrix.folder }} | |
New_PKG_VERSION=${{ steps.check.outputs.New_PKG_VERSION }} | |
if [ ! -n "${{ matrix.version_line }}" ] ; then | |
sed -i "/^${{ matrix.version_head }}/c\${{ matrix.version_head }}$New_PKG_VERSION" Makefile; | |
else | |
sed -i "${{ matrix.version_line }}c ${{ matrix.version_head }}$New_PKG_VERSION" Makefile; | |
fi | |
cd && cd pack && mkdir -p ${{ matrix.pakcages }} && cd ${{ matrix.pakcages }} | |
wget -P / ${{ matrix.release_download_url }}$New_PKG_VERSION${{ matrix.file_name }} | |
file_name=${{ matrix.file_name }} | |
is_v=$(echo ${{ matrix.release_download_url }} | awk -F/ '{print $NF}') | |
if [ ! -n "${{ matrix.file_name }}" ]; then PKG_HASH=$(sha256sum $is_v$New_PKG_VERSION) && PKG_HASH=${PKG_HASH%% *}; else PKG_HASH=$(sha256sum ${file_name##*/}) && PKG_HASH=${PKG_HASH%% *}; fi; | |
cd && cd $GITHUB_WORKSPACE/${{ matrix.folder }} | |
if [ ! -n "${{ matrix.hash_line }}" ] ; then | |
sed -i "/^${{ matrix.hash_head }}/c\${{ matrix.hash_head }}$PKG_HASH" Makefile; | |
else | |
sed -i "${{ matrix.hash_line }}c ${{ matrix.hash_head }}$PKG_HASH" Makefile; | |
fi | |
echo "已更新${{ matrix.pakcages }}版本到: $New_PKG_VERSION" | |
echo "${{ matrix.pakcages }} Hash:$PKG_HASH" | |
cd && cd pack | |
echo ":white_check_mark: ${{ matrix.pakcages }}: update to $New_PKG_VERSION" >> commit_messages.txt | |
echo "version=$New_PKG_VERSION" >> $GITHUB_OUTPUT | |
cd && cd $GITHUB_WORKSPACE | |
echo "branch_exists=$(git ls-remote --heads origin patches-${{ matrix.pakcages }}-$New_PKG_VERSION | tr -d '\n')" >> $GITHUB_OUTPUT | |
- name: Create Pull Request | |
id: cpr | |
if: steps.check.outputs.status == 'success' && steps.check.outputs.New_PKG_VERSION != '' && steps.update.outputs.branch_exists == '' && !cancelled() | |
uses: peter-evans/create-pull-request@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
commit-message: "${{ matrix.pakcages }}: update to ${{ steps.update.outputs.version }}" | |
committer: action <[email protected]> | |
author: ${{ github.actor }} <${{ github.actor_id }}+${{ github.actor }}@users.noreply.github.com> | |
signoff: false | |
branch: patches-${{ matrix.pakcages }}-${{ steps.update.outputs.version }} | |
base: main | |
delete-branch: true | |
body: | | |
${{ matrix.pakcages }}: update to ${{ steps.update.outputs.version }} | |
title: "${{ matrix.pakcages }}: update to ${{ steps.update.outputs.version }}" | |
labels: | | |
automated-pr | |
draft: false | |