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_LKEY: ${{ secrets.MIKRO_NPK_SIGN_PUBLIC_LKEY }} 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 > ./publish/NEWEST6.${{ matrix.channel }} cp CHANGELOG ./publish/$LATEST_VERSION/ cp ./all_packages/*.npk ./publish/$LATEST_VERSION/ sudo chown -R root:root ./publish/ sudo apt-get install -y lftp > /dev/null 2>&1 sudo -E lftp -u ${{ secrets.SSH_USERNAME }},'${{ secrets.SSH_PASSWORD }}' sftp://${{ secrets.SSH_SERVER }}:${{ secrets.SSH_PORT }} <