Browse Source
new file: .github/workflows/mikrotik_patch_6.yml
new file: .github/workflows/mikrotik_patch_6.yml
renamed: .github/workflows/mikrotik_patch.yml -> .github/workflows/mikrotik_patch_7.yml modified: README.md modified: README_CN.md new file: busybox/busybox_x86 deleted: busybox/busybox_x86_64 renamed: keygen/keygen_x86_64 -> keygen/keygen_x86 modified: patch.pypull/55/head
8 changed files with 289 additions and 30 deletions
-
254.github/workflows/mikrotik_patch_6.yml
-
48.github/workflows/mikrotik_patch_7.yml
-
2README.md
-
3README_CN.md
-
BINbusybox/busybox_x86
-
BINbusybox/busybox_x86_64
-
BINkeygen/keygen_x86
-
12patch.py
@ -0,0 +1,254 @@ |
|||||
|
name: Patch Mikrotik RouterOS 6.x |
||||
|
|
||||
|
on: |
||||
|
# push: |
||||
|
# branches: [ "main" ] |
||||
|
schedule: |
||||
|
- cron: "0 0 * * *" |
||||
|
workflow_dispatch: |
||||
|
|
||||
|
permissions: |
||||
|
contents: write |
||||
|
|
||||
|
jobs: |
||||
|
Patch_RouterOS: |
||||
|
runs-on: ubuntu-22.04 |
||||
|
strategy: |
||||
|
matrix: |
||||
|
channel: [long-term,stable] |
||||
|
env: |
||||
|
TZ: 'Asia/Shanghai' |
||||
|
LATEST_VERSION: "" |
||||
|
BUILD_TIME: "0" |
||||
|
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 }} |
||||
|
MIKRO_LICENSE_PUBLIC_KEY: ${{ secrets.MIKRO_LICENSE_PUBLIC_KEY }} |
||||
|
MIKRO_NPK_SIGN_PUBLIC_LKEY: ${{ secrets.MIKRO_NPK_SIGN_PUBLIC_LKEY }} |
||||
|
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 }} |
||||
|
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) |
||||
|
if [ "${{ matrix.channel }}" == "long-term" ]; then |
||||
|
LATEST="LATEST.6fix" |
||||
|
elif [ "${{ matrix.channel }}" == "stable" ]; then |
||||
|
LATEST="LATEST.6" |
||||
|
fi |
||||
|
LATEST_VERSION=$(wget -nv -O - https://upgrade.mikrotik.com/routeros/$LATEST | 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/$LATEST | 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=$(date +"%s") |
||||
|
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 |
||||
|
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 -E python3 patch.py kernel ./isolinux/initrd.rgz |
||||
|
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 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/ |
||||
|
sudo echo -e 'default system\nLABEL system\n\tKERNEL linux\n\tAPPEND load_ramdisk=1 initrd=initrd.rgz -hdd-install' \ |
||||
|
> ./install/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 mount -o loop,rw chr-$LATEST_VERSION.img ./chr |
||||
|
sudo -E python3 patch.py kernel ./chr/boot/initrd.rgz |
||||
|
sudo cp ./all_packages/ipv6-$LATEST_VERSION.npk ./chr/var/pdb/ipv6/image |
||||
|
sudo cp ./all_packages/dude-$LATEST_VERSION.npk ./chr/var/pdb/dude/image |
||||
|
sudo cp ./all_packages/system-$LATEST_VERSION.npk ./chr/var/pdb/routeros-x86/image |
||||
|
sudo umount ./chr |
||||
|
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: | |
||||
|
mkdir -p ./publish/$LATEST_VERSION |
||||
|
if [ "${{ matrix.channel }}" == "long-term" ]; then |
||||
|
LATEST="LATEST.6fix" |
||||
|
elif [ "${{ matrix.channel }}" == "stable" ]; then |
||||
|
LATEST="LATEST.6" |
||||
|
fi |
||||
|
echo $LATEST_VERSION $BUILD_TIME > ./publish/$LATEST |
||||
|
cp CHANGELOG ./publish/$LATEST_VERSION/ |
||||
|
cp ./all_packages/*.npk ./publish/$LATEST_VERSION/ |
||||
|
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 }} <<EOF |
||||
|
set sftp:auto-confirm yes |
||||
|
mirror --reverse --verbose --only-newer ./publish ${{ secrets.SSH_DIRECTORY }} |
||||
|
bye |
||||
|
EOF |
||||
|
|
||||
|
- 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: ${{ matrix.channel == 'stable'}} |
||||
|
prerelease: ${{ matrix.channel == 'testing' }} |
||||
|
files: | |
||||
|
mikrotik-${{ env.LATEST_VERSION }}.iso |
||||
|
chr-${{ env.LATEST_VERSION }}*.zip |
||||
|
install-image-${{ env.LATEST_VERSION }}.zip |
||||
|
system-${{ env.LATEST_VERSION }}.npk |
||||
|
all_packages-x86-${{ env.LATEST_VERSION }}.zip |
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue