Merge branch 'master' of https://github.com/Hyy2001X/AutoBuild-Actions
This commit is contained in:
commit
22abd77e26
|
@ -0,0 +1,146 @@
|
|||
#!/bin/bash
|
||||
# https://github.com/Hyy2001X/AutoBuild-Actions
|
||||
# AutoBuild Module by Hyy2001
|
||||
# AutoBuild Actions
|
||||
|
||||
Diy_Core() {
|
||||
Author=Hyy2001
|
||||
Default_Device=d-team_newifi-d2
|
||||
}
|
||||
|
||||
Diy-Part1() {
|
||||
[ -e feeds.conf.default ] && sed -i "s/#src-git helloworld/src-git helloworld/g" feeds.conf.default
|
||||
[ ! -d package/lean ] && mkdir -p package/lean
|
||||
|
||||
Replace_File mac80211.sh package/kernel/mac80211/files/lib/wifi
|
||||
Replace_File system package/base-files/files/etc/config
|
||||
Replace_File AutoUpdate.sh package/base-files/files/bin
|
||||
Replace_File AutoExpand.sh package/base-files/files/bin
|
||||
Replace_File banner package/base-files/files/etc
|
||||
|
||||
ExtraPackages svn network/services dnsmasq https://github.com/openwrt/openwrt/trunk/package/network/services
|
||||
ExtraPackages svn network/services dropbear https://github.com/openwrt/openwrt/trunk/package/network/services
|
||||
ExtraPackages svn network/services ppp https://github.com/openwrt/openwrt/trunk/package/network/services
|
||||
# ExtraPackages svn network/services hostapd https://github.com/openwrt/openwrt/trunk/package/network/services
|
||||
# ExtraPackages svn kernel mt76 https://github.com/openwrt/openwrt/trunk/package/kernel
|
||||
|
||||
ExtraPackages git lean luci-app-autoupdate https://github.com/Hyy2001X main
|
||||
ExtraPackages git lean luci-theme-argon https://github.com/jerrykuku 18.06
|
||||
ExtraPackages git other luci-app-argon-config https://github.com/jerrykuku master
|
||||
ExtraPackages git other luci-app-adguardhome https://github.com/Hyy2001X master
|
||||
ExtraPackages svn other luci-app-smartdns https://github.com/project-openwrt/openwrt/trunk/package/ntlf9t
|
||||
ExtraPackages svn other smartdns https://github.com/project-openwrt/openwrt/trunk/package/ntlf9t
|
||||
ExtraPackages git other OpenClash https://github.com/vernesong master
|
||||
ExtraPackages git other luci-app-serverchan https://github.com/tty228 master
|
||||
ExtraPackages svn other luci-app-socat https://github.com/project-openwrt/openwrt/trunk/package/lienol
|
||||
# [UPX 压缩] ExtraPackages git other openwrt-upx https://github.com/Hyy2001X master
|
||||
# [应用过滤] ExtraPackages git OAF openwrt-OpenAppFilter https://github.com/Lienol master
|
||||
# [AdGuardHome 核心] ExtraPackages svn other AdGuardHome https://github.com/project-openwrt/openwrt/trunk/package/ntlf9t
|
||||
}
|
||||
|
||||
Diy-Part2() {
|
||||
GET_TARGET_INFO
|
||||
Replace_File mwan3 package/feeds/packages/mwan3/files/etc/config
|
||||
sed -i 's/143/143,25,5222/' package/feeds/helloworld/luci-app-ssr-plus/root/etc/init.d/shadowsocksr
|
||||
# ExtraPackages svn feeds/packages mwan3 https://github.com/openwrt/packages/trunk/net
|
||||
echo "Author: $Author"
|
||||
echo "Openwrt Version: $Openwrt_Version"
|
||||
echo "AutoUpdate Version: $AutoUpdate_Version"
|
||||
echo "Router: $TARGET_PROFILE"
|
||||
sed -i "s?$Lede_Version?$Lede_Version Compiled by $Author [$Display_Date]?g" $Default_File
|
||||
echo "$Openwrt_Version" > package/base-files/files/etc/openwrt_info
|
||||
sed -i "s?Openwrt?Openwrt $Openwrt_Version / AutoUpdate $AutoUpdate_Version?g" package/base-files/files/etc/banner
|
||||
}
|
||||
|
||||
Diy-Part3() {
|
||||
GET_TARGET_INFO
|
||||
Default_Firmware=openwrt-$TARGET_BOARD-$TARGET_SUBTARGET-$TARGET_PROFILE-squashfs-sysupgrade.bin
|
||||
AutoBuild_Firmware=AutoBuild-$TARGET_PROFILE-Lede-${Openwrt_Version}.bin
|
||||
AutoBuild_Detail=AutoBuild-$TARGET_PROFILE-Lede-${Openwrt_Version}.detail
|
||||
mkdir -p bin/Firmware
|
||||
echo "Firmware: $AutoBuild_Firmware"
|
||||
mv bin/targets/$TARGET_BOARD/$TARGET_SUBTARGET/$Default_Firmware bin/Firmware/$AutoBuild_Firmware
|
||||
echo "[$(date "+%H:%M:%S")] Calculating MD5 and SHA256 ..."
|
||||
Firmware_MD5=$(md5sum bin/Firmware/$AutoBuild_Firmware | cut -d ' ' -f1)
|
||||
Firmware_SHA256=$(sha256sum bin/Firmware/$AutoBuild_Firmware | cut -d ' ' -f1)
|
||||
echo -e "MD5: $Firmware_MD5\nSHA256: $Firmware_SHA256"
|
||||
touch bin/Firmware/$AutoBuild_Detail
|
||||
echo -e "\nMD5:$Firmware_MD5\nSHA256:$Firmware_SHA256" >> bin/Firmware/$AutoBuild_Detail
|
||||
}
|
||||
|
||||
GET_TARGET_INFO() {
|
||||
Diy_Core
|
||||
[ -e $GITHUB_WORKSPACE/Openwrt.info ] && . $GITHUB_WORKSPACE/Openwrt.info
|
||||
AutoUpdate_Version=$(awk 'NR==6' package/base-files/files/bin/AutoUpdate.sh | awk -F '[="]+' '/Version/{print $2}')
|
||||
Default_File="package/lean/default-settings/files/zzz-default-settings"
|
||||
Lede_Version=$(egrep -o "R[0-9]+\.[0-9]+\.[0-9]+" $Default_File)
|
||||
Openwrt_Version="$Lede_Version-$Compile_Date"
|
||||
TARGET_PROFILE=$(egrep -o "CONFIG_TARGET.*DEVICE.*=y" .config | sed -r 's/.*DEVICE_(.*)=y/\1/')
|
||||
[ -z "$TARGET_PROFILE" ] && TARGET_PROFILE="$Default_Device"
|
||||
TARGET_BOARD=$(awk -F '[="]+' '/TARGET_BOARD/{print $2}' .config)
|
||||
TARGET_SUBTARGET=$(awk -F '[="]+' '/TARGET_SUBTARGET/{print $2}' .config)
|
||||
}
|
||||
|
||||
ExtraPackages() {
|
||||
PKG_PROTO=$1
|
||||
PKG_DIR=$2
|
||||
PKG_NAME=$3
|
||||
REPO_URL=$4
|
||||
REPO_BRANCH=$5
|
||||
|
||||
[ -d package/$PKG_DIR ] && mkdir -p package/$PKG_DIR
|
||||
[ -d package/$PKG_DIR/$PKG_NAME ] && rm -rf package/$PKG_DIR/$PKG_NAME
|
||||
[ -d $PKG_NAME ] && rm -rf $PKG_NAME
|
||||
Retry_Times=3
|
||||
while [ ! -e $PKG_NAME/Makefile ]
|
||||
do
|
||||
echo "[$(date "+%H:%M:%S")] Checking out package [$PKG_NAME] ..."
|
||||
case $PKG_PROTO in
|
||||
git)
|
||||
git clone -b $REPO_BRANCH $REPO_URL/$PKG_NAME $PKG_NAME > /dev/null 2>&1
|
||||
;;
|
||||
svn)
|
||||
svn checkout $REPO_URL/$PKG_NAME $PKG_NAME > /dev/null 2>&1
|
||||
esac
|
||||
if [ -e $PKG_NAME/Makefile ] || [ -e $PKG_NAME/README* ];then
|
||||
echo "[$(date "+%H:%M:%S")] Package [$PKG_NAME] is detected!"
|
||||
mv $PKG_NAME package/$PKG_DIR
|
||||
break
|
||||
else
|
||||
[ $Retry_Times -lt 1 ] && echo "[$(date "+%H:%M:%S")] Skip check out package [$PKG_NAME] ..." && break
|
||||
echo "[$(date "+%H:%M:%S")] [Error] [$Retry_Times] Checkout failed,retry in 3s ..."
|
||||
Retry_Times=$(($Retry_Times - 1))
|
||||
rm -rf $PKG_NAME > /dev/null 2>&1
|
||||
sleep 3
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
Replace_File() {
|
||||
FILE_NAME=$1
|
||||
PATCH_DIR=$GITHUB_WORKSPACE/openwrt/$2
|
||||
FILE_RENAME=$3
|
||||
|
||||
[ ! -d $PATCH_DIR ] && mkdir -p $PATCH_DIR
|
||||
if [ -f $GITHUB_WORKSPACE/Customize/$FILE_NAME ];then
|
||||
if [ -e $GITHUB_WORKSPACE/Customize/$FILE_NAME ];then
|
||||
echo "[$(date "+%H:%M:%S")] Customize File [$FILE_NAME] is detected!"
|
||||
if [ -z $FILE_RENAME ];then
|
||||
[ -e $PATCH_DIR/$FILE_NAME ] && rm -f $PATCH_DIR/$FILE_NAME
|
||||
mv -f $GITHUB_WORKSPACE/Customize/$FILE_NAME $PATCH_DIR/$1
|
||||
else
|
||||
[ -e $PATCH_DIR/$FILE_NAME ] && rm -f $PATCH_DIR/$3
|
||||
mv -f $GITHUB_WORKSPACE/Customize/$FILE_NAME $PATCH_DIR/$3
|
||||
fi
|
||||
else
|
||||
echo "[$(date "+%H:%M:%S")] Customize File [$FILE_NAME] is not detected,skip move ..."
|
||||
fi
|
||||
else
|
||||
if [ -d $GITHUB_WORKSPACE/Customize/$FILE_NAME ];then
|
||||
echo "[$(date "+%H:%M:%S")] Customize Folder [$FILE_NAME] is detected !"
|
||||
mv -f $GITHUB_WORKSPACE/Customize/$FILE_NAME $PATCH_DIR
|
||||
else
|
||||
echo "[$(date "+%H:%M:%S")] Customize Folder [$FILE_NAME] is not detected,skip move ..."
|
||||
fi
|
||||
fi
|
||||
}
|
Loading…
Reference in New Issue