Skip to content

shadow-tls

shadow-tls #870

Workflow file for this run

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