mirror of
https://github.com/elseif/MikroTikPatch.git
synced 2025-01-23 13:35:09 +03:00
3207b0ccd3
Signed-off-by: elseif <elseif@live.cn>
275 lines
12 KiB
YAML
275 lines
12 KiB
YAML
name: Patch Mikrotik RouterOS 6.x
|
|
|
|
on:
|
|
# push:
|
|
# branches: [ "main" ]
|
|
schedule:
|
|
- cron: "0 0 * * *"
|
|
workflow_dispatch:
|
|
|
|
permissions:
|
|
contents: write
|
|
|
|
env:
|
|
CUSTOM_LICENSE_PRIVATE_KEY: ${{ secrets.CUSTOM_LICENSE_PRIVATE_KEY }}
|
|
CUSTOM_LICENSE_PUBLIC_KEY: ${{ secrets.CUSTOM_LICENSE_PUBLIC_KEY }}
|
|
CUSTOM_NPK_SIGN_PRIVATE_KEY: ${{ secrets.CUSTOM_NPK_SIGN_PRIVATE_KEY }}
|
|
CUSTOM_NPK_SIGN_PUBLIC_KEY: ${{ secrets.CUSTOM_NPK_SIGN_PUBLIC_KEY }}
|
|
CUSTOM_CLOUD_PUBLIC_KEY: ${{ secrets.CUSTOM_CLOUD_PUBLIC_KEY }}
|
|
MIKRO_LICENSE_PUBLIC_KEY: ${{ secrets.MIKRO_LICENSE_PUBLIC_KEY }}
|
|
MIKRO_NPK_SIGN_PUBLIC_KEY: ${{ secrets.MIKRO_NPK_SIGN_PUBLIC_KEY }}
|
|
MIKRO_CLOUD_PUBLIC_KEY: ${{ secrets.MIKRO_CLOUD_PUBLIC_KEY }}
|
|
MIKRO_LICENCE_URL: ${{ secrets.MIKRO_LICENCE_URL }}
|
|
CUSTOM_LICENCE_URL: ${{ secrets.CUSTOM_LICENCE_URL }}
|
|
MIKRO_UPGRADE_URL: ${{ secrets.MIKRO_UPGRADE_URL }}
|
|
CUSTOM_UPGRADE_URL: ${{ secrets.CUSTOM_UPGRADE_URL }}
|
|
MIKRO_RENEW_URL: ${{ secrets.MIKRO_RENEW_URL }}
|
|
CUSTOM_RENEW_URL: ${{ secrets.CUSTOM_RENEW_URL }}
|
|
MIKRO_CLOUD_URL: ${{ secrets.MIKRO_CLOUD_URL }}
|
|
CUSTOM_CLOUD_URL: ${{ secrets.CUSTOM_CLOUD_URL }}
|
|
|
|
jobs:
|
|
Set_BuildTime:
|
|
runs-on: ubuntu-22.04
|
|
outputs:
|
|
BUILD_TIME: ${{ steps.set_buildtime.outputs.BUILD_TIME }}
|
|
steps:
|
|
- name: Set build time
|
|
id: set_buildtime
|
|
run: echo "BUILD_TIME=$(date +'%s')" >> $GITHUB_OUTPUT
|
|
|
|
Patch_RouterOS:
|
|
needs: Set_BuildTime
|
|
runs-on: ubuntu-22.04
|
|
strategy:
|
|
matrix:
|
|
channel: [long-term,stable]
|
|
env:
|
|
TZ: 'Asia/Shanghai'
|
|
LATEST_VERSION: ""
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: '3.11'
|
|
|
|
- name: Get latest routeros version
|
|
id: get_latest
|
|
run: |
|
|
echo $(uname -a)
|
|
LATEST_VERSION=$(wget -nv -O - https://upgrade.mikrotik.com/routeros/NEWEST6.${{ matrix.channel }} | cut -d ' ' -f1)
|
|
echo Latest Version:$LATEST_VERSION
|
|
if [ "${{ github.event_name }}" == "schedule" ]; then
|
|
_LATEST_VERSION=$(wget -nv -O - https://${{ env.CUSTOM_UPGRADE_URL }}/routeros/NEWEST6.${{ matrix.channel }} | cut -d ' ' -f1)
|
|
if [ "$_LATEST_VERSION" == "$LATEST_VERSION" ]; then
|
|
echo "No new version found"
|
|
echo "has_new_version=false" >> $GITHUB_OUTPUT
|
|
exit 0
|
|
fi
|
|
fi
|
|
echo "has_new_version=true" >> $GITHUB_OUTPUT
|
|
BUILD_TIME=${{ needs.Set_BuildTime.outputs.BUILD_TIME }}
|
|
echo Build Time:$BUILD_TIME
|
|
wget -nv -O CHANGELOG https://${{ env.MIKRO_UPGRADE_URL }}/routeros/$LATEST_VERSION/CHANGELOG
|
|
cat CHANGELOG
|
|
echo "LATEST_VERSION=${LATEST_VERSION}" >> $GITHUB_ENV
|
|
echo "BUILD_TIME=${BUILD_TIME}" >> $GITHUB_ENV
|
|
|
|
|
|
- name: Cache mikrotik-${{ env.LATEST_VERSION }}.iso
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
id: cache-mikrotik
|
|
uses: actions/cache@v4
|
|
with:
|
|
path: |
|
|
mikrotik.iso
|
|
key: mikrotik-${{ env.LATEST_VERSION }}
|
|
|
|
- name: Get mikrotik-${{ env.LATEST_VERSION }}.iso
|
|
if: steps.get_latest.outputs.has_new_version == 'true' && steps.cache-mikrotik.outputs.cache-hit != 'true'
|
|
run: |
|
|
sudo wget -nv -O mikrotik.iso https://download.mikrotik.com/routeros/$LATEST_VERSION/mikrotik-$LATEST_VERSION.iso
|
|
|
|
|
|
- name: Patch mikrotik-${{ env.LATEST_VERSION }}.iso
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
run: |
|
|
sudo apt-get install -y mkisofs xorriso > /dev/null
|
|
sudo mkdir ./iso
|
|
sudo mount -o loop,ro mikrotik.iso ./iso
|
|
sudo mkdir ./new_iso
|
|
sudo cp -r ./iso/* ./new_iso/
|
|
sudo rsync -a ./iso/ ./new_iso/
|
|
sudo umount ./iso
|
|
sudo rm -rf ./iso
|
|
sudo mv ./new_iso/system-$LATEST_VERSION.npk ./
|
|
sudo -E python3 patch.py npk system-$LATEST_VERSION.npk
|
|
sudo -E python3 patch.py kernel ./new_iso/isolinux/initrd.rgz
|
|
NPK_FILES=$(find ./new_iso/*.npk)
|
|
for file in $NPK_FILES; do
|
|
sudo -E python3 npk.py sign $file $file
|
|
done
|
|
sudo cp system-$LATEST_VERSION.npk ./new_iso/
|
|
sudo mkisofs -o mikrotik-$LATEST_VERSION.iso \
|
|
-V "MikroTik $LATEST_VERSION" \
|
|
-sysid "" -preparer "MiKroTiK" \
|
|
-publisher "" -A "MiKroTiK RouterOS" \
|
|
-input-charset utf-8 \
|
|
-b isolinux/isolinux.bin \
|
|
-c isolinux/boot.cat \
|
|
-no-emul-boot \
|
|
-boot-load-size 4 \
|
|
-boot-info-table \
|
|
-R -J \
|
|
./new_iso
|
|
|
|
sudo mkdir ./all_packages
|
|
sudo cp ./new_iso/*.npk ./all_packages/
|
|
sudo rm -rf ./new_iso
|
|
cd ./all_packages
|
|
sudo zip ../all_packages-x86-$LATEST_VERSION.zip *.npk
|
|
cd ..
|
|
|
|
|
|
- name: Create install-image-${{ env.LATEST_VERSION }}.img
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
run: |
|
|
sudo modprobe nbd
|
|
sudo apt-get update
|
|
sudo apt-get install -y qemu-utils extlinux > /dev/null
|
|
truncate --size 64M install-image-$LATEST_VERSION.img
|
|
sudo qemu-nbd -c /dev/nbd0 -f raw install-image-$LATEST_VERSION.img
|
|
sudo mkfs.vfat -n "Install" /dev/nbd0
|
|
sudo mkdir ./install
|
|
sudo mount /dev/nbd0 ./install
|
|
sudo extlinux --install -H 64 -S 32 ./install/
|
|
echo -e 'default system\nLABEL system\n\tKERNEL linux\n\tAPPEND load_ramdisk=1 initrd=initrd.rgz -hdd-install' \
|
|
> syslinux.cfg
|
|
sudo cp syslinux.cfg ./install/
|
|
sudo rm syslinux.cfg
|
|
NPK_FILES=($(find ./all_packages/*.npk))
|
|
for ((i=1; i<=${#NPK_FILES[@]}; i++))
|
|
do
|
|
echo "${NPK_FILES[$i-1]}=>$i.npk"
|
|
sudo cp ${NPK_FILES[$i-1]} ./install/$i.npk
|
|
done
|
|
sudo touch ./install/CHOOSE
|
|
sudo touch ./install/autorun.scr
|
|
sudo umount /dev/nbd0
|
|
sudo qemu-nbd -d /dev/nbd0
|
|
sudo rm -rf ./install
|
|
sudo zip install-image-$LATEST_VERSION.zip ./install-image-$LATEST_VERSION.img
|
|
sudo rm ./install-image-$LATEST_VERSION.img
|
|
|
|
- name: Cache chr-${{ env.LATEST_VERSION }}.img.zip
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
id: cache-chr-img
|
|
uses: actions/cache@v4
|
|
with:
|
|
path: |
|
|
chr.img
|
|
key: chr-${{ env.LATEST_VERSION }}.img
|
|
|
|
- name: Get chr-${{ env.LATEST_VERSION }}.img
|
|
if: steps.get_latest.outputs.has_new_version == 'true' && steps.cache-chr-img.outputs.cache-hit != 'true'
|
|
run: |
|
|
sudo wget -nv -O chr.img.zip https://download.mikrotik.com/routeros/$LATEST_VERSION/chr-$LATEST_VERSION.img.zip
|
|
sudo unzip chr.img.zip
|
|
sudo rm chr.img.zip
|
|
sudo mv chr-$LATEST_VERSION.img chr.img
|
|
|
|
- name: Create chr-${{ env.LATEST_VERSION }}.img
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
run: |
|
|
sudo mkdir ./chr
|
|
sudo cp chr.img chr-$LATEST_VERSION.img
|
|
sudo qemu-nbd -c /dev/nbd0 -f raw chr-$LATEST_VERSION.img
|
|
sudo -E python3 patch.py block /dev/nbd0p1 boot/initrd.rgz
|
|
sudo mount /dev/nbd0p1 ./chr
|
|
sudo cp ./all_packages/dude-$LATEST_VERSION.npk ./chr/var/pdb/dude/image
|
|
sudo -E python3 patch.py npk ./chr/var/pdb/routeros-x86/image
|
|
sudo cp ./chr/var/pdb/routeros-x86/image ./all_packages/routeros-x86-$LATEST_VERSION.npk
|
|
sudo cp ./all_packages/routeros-x86-$LATEST_VERSION.npk routeros-x86-$LATEST_VERSION.npk
|
|
sudo umount ./chr
|
|
sudo qemu-nbd -d /dev/nbd0
|
|
sudo rm -rf ./chr
|
|
|
|
sudo qemu-img convert -f raw -O qcow2 chr-$LATEST_VERSION.img chr-$LATEST_VERSION.qcow2
|
|
sudo qemu-img convert -f raw -O vmdk chr-$LATEST_VERSION.img chr-$LATEST_VERSION.vmdk
|
|
sudo qemu-img convert -f raw -O vpc chr-$LATEST_VERSION.img chr-$LATEST_VERSION.vhd
|
|
sudo qemu-img convert -f raw -O vhdx chr-$LATEST_VERSION.img chr-$LATEST_VERSION.vhdx
|
|
sudo qemu-img convert -f raw -O vdi chr-$LATEST_VERSION.img chr-$LATEST_VERSION.vdi
|
|
|
|
sudo zip chr-$LATEST_VERSION.qcow2.zip chr-$LATEST_VERSION.qcow2
|
|
sudo zip chr-$LATEST_VERSION.vmdk.zip chr-$LATEST_VERSION.vmdk
|
|
sudo zip chr-$LATEST_VERSION.vhd.zip chr-$LATEST_VERSION.vhd
|
|
sudo zip chr-$LATEST_VERSION.vhdx.zip chr-$LATEST_VERSION.vhdx
|
|
sudo zip chr-$LATEST_VERSION.vdi.zip chr-$LATEST_VERSION.vdi
|
|
sudo zip chr-$LATEST_VERSION.img.zip chr-$LATEST_VERSION.img
|
|
|
|
sudo rm chr-$LATEST_VERSION$ARCH.qcow2
|
|
sudo rm chr-$LATEST_VERSION$ARCH.vmdk
|
|
sudo rm chr-$LATEST_VERSION$ARCH.vhd
|
|
sudo rm chr-$LATEST_VERSION$ARCH.vhdx
|
|
sudo rm chr-$LATEST_VERSION$ARCH.vdi
|
|
sudo rm chr-$LATEST_VERSION$ARCH.img
|
|
|
|
|
|
- name: Upload Files
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
run: |
|
|
sudo mkdir -p ./publish/$LATEST_VERSION
|
|
echo $LATEST_VERSION $BUILD_TIME | sudo tee ./publish/NEWEST6.${{ matrix.channel }}
|
|
sudo cp CHANGELOG ./publish/$LATEST_VERSION/
|
|
sudo cp ./all_packages/*.npk ./publish/$LATEST_VERSION/
|
|
sudo chown -R root:root ./publish/
|
|
sudo apt-get install -y lftp ssh sshpass > /dev/null 2>&1
|
|
sudo -E lftp -u ${{ secrets.SSH_USERNAME }},'${{ secrets.SSH_PASSWORD }}' sftp://${{ secrets.SSH_SERVER }}:${{ secrets.SSH_PORT }} <<EOF
|
|
set sftp:auto-confirm yes
|
|
mirror --reverse --verbose --only-newer ./publish ${{ secrets.SSH_DIRECTORY }}
|
|
bye
|
|
EOF
|
|
sshpass -p "${{ secrets.SSH_PASSWORD }}" ssh -o StrictHostKeyChecking=no -p ${{ secrets.SSH_PORT }} ${{ secrets.SSH_USERNAME }}@${{ secrets.SSH_SERVER }} "chown -R 32768:32768 /rw/disk/${{ secrets.SSH_DIRECTORY }}/"
|
|
- name: Clear Cloudflare cache
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
run: |
|
|
curl --request POST --url "https://api.cloudflare.com/client/v4/zones/fe6831ed6dc9e6235e69ef2a31f2e7fe/purge_cache" \
|
|
--header "Authorization: Bearer 9GDQkzU51QXaqzp1qMjyFKpyeJyOdnNoG9GZQaGP" \
|
|
--header "Content-Type:application/json" \
|
|
--data '{"purge_everything": true}'
|
|
|
|
- name: Delete Release tag ${{ env.LATEST_VERSION }}
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
run: |
|
|
HEADER="Authorization: token ${{ secrets.GITHUB_TOKEN }}"
|
|
RELEASE_INFO=$(curl -s -H $HEADER https://api.github.com/repos/${{ github.repository }}/releases/tags/$LATEST_VERSION$ARCH)
|
|
RELEASE_ID=$(echo $RELEASE_INFO | jq -r '.id')
|
|
echo "Release ID: $RELEASE_ID"
|
|
if [ "$RELEASE_ID" != "null" ]; then
|
|
curl -X DELETE -H "$HEADER" https://api.github.com/repos/${{ github.repository }}/git/refs/tags/$LATEST_VERSION$ARCH
|
|
echo "Tag $LATEST_VERSION$ARCH deleted successfully."
|
|
curl -X DELETE -H "$HEADER" https://api.github.com/repos/${{ github.repository }}/releases/$RELEASE_ID
|
|
echo "Release with tag $LATEST_VERSION$ARCH deleted successfully."
|
|
else
|
|
echo "Release not found for tag: $LATEST_VERSION)"
|
|
fi
|
|
|
|
- name: Create Release tag ${{ env.LATEST_VERSION }}
|
|
if: steps.get_latest.outputs.has_new_version == 'true'
|
|
uses: softprops/action-gh-release@v2
|
|
with:
|
|
name: "RouterOS ${{ env.LATEST_VERSION }}"
|
|
body_path: "CHANGELOG"
|
|
tag_name: ${{ env.LATEST_VERSION }}
|
|
make_latest: false
|
|
prerelease: ${{ matrix.channel == 'testing' }}
|
|
files: |
|
|
mikrotik-${{ env.LATEST_VERSION }}.iso
|
|
chr-${{ env.LATEST_VERSION }}*.zip
|
|
install-image-${{ env.LATEST_VERSION }}.zip
|
|
routeros-x86-${{ env.LATEST_VERSION }}.npk
|
|
all_packages-x86-${{ env.LATEST_VERSION }}.zip
|