General code cleanup and refactoring
This commit is contained in:
409
openwrtbuilder
409
openwrtbuilder
@@ -1,18 +1,13 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
#
|
# Builds and deploys OpenWRT images
|
||||||
# Copyright 2022-24 Bryan C. Roessler
|
# Copyright 2022-24 Bryan C. Roessler
|
||||||
#
|
|
||||||
# Build and deploy OpenWRT images
|
|
||||||
#
|
|
||||||
# Apache 2.0 License
|
# Apache 2.0 License
|
||||||
#
|
|
||||||
# See README.md and ./profiles
|
# See README.md and ./profiles
|
||||||
#
|
|
||||||
|
|
||||||
# Set default release
|
# Set default release
|
||||||
: "${RELEASE:="23.05.5"}"
|
: "${RELEASE:="23.05.5"}"
|
||||||
|
|
||||||
printHelp() {
|
print_help() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
cat <<-'EOF'
|
cat <<-'EOF'
|
||||||
@@ -51,10 +46,9 @@ printHelp() {
|
|||||||
|
|
||||||
init() {
|
init() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
declare -g ID RPM_MGR SCRIPTDIR DL_TOOL
|
declare -g ID RPM_MGR SCRIPTDIR DL_TOOL
|
||||||
|
|
||||||
(( DEBUG )) || echo "To enable debugging output, use --debug or -d"
|
((DEBUG)) || echo "To enable debugging output, use --debug or -d"
|
||||||
|
|
||||||
# Save the script directory
|
# Save the script directory
|
||||||
# https://stackoverflow.com/a/4774063
|
# https://stackoverflow.com/a/4774063
|
||||||
@@ -65,7 +59,7 @@ init() {
|
|||||||
else
|
else
|
||||||
echo "/etc/os-release not found"
|
echo "/etc/os-release not found"
|
||||||
echo "Your OS is unsupported"
|
echo "Your OS is unsupported"
|
||||||
printHelp
|
print_help
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -73,27 +67,18 @@ init() {
|
|||||||
|
|
||||||
# normalize distro ID
|
# normalize distro ID
|
||||||
case "$ID" in
|
case "$ID" in
|
||||||
debian|arch)
|
debian|arch) ;;
|
||||||
;;
|
|
||||||
centos|fedora)
|
centos|fedora)
|
||||||
if hash dnf &>/dev/null; then
|
if command -v dnf &>/dev/null; then
|
||||||
RPM_MGR="dnf"
|
RPM_MGR="dnf"
|
||||||
elif hash yum &>/dev/null; then
|
elif command -v yum &>/dev/null; then
|
||||||
RPM_MGR="yum"
|
RPM_MGR="yum"
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
rhel)
|
rhel) ID="centos" ;;
|
||||||
ID="centos"
|
linuxmint|neon|*ubuntu*) ID="ubuntu" ;;
|
||||||
;;
|
*suse*) ID="suse" ;;
|
||||||
linuxmint|neon|*ubuntu*)
|
raspbian) ID="debian" ;;
|
||||||
ID="ubuntu"
|
|
||||||
;;
|
|
||||||
*suse*)
|
|
||||||
ID="suse"
|
|
||||||
;;
|
|
||||||
raspbian)
|
|
||||||
ID="debian"
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
echo "Autodetecting distro, this may be unreliable"
|
echo "Autodetecting distro, this may be unreliable"
|
||||||
if hash dnf &>/dev/null; then
|
if hash dnf &>/dev/null; then
|
||||||
@@ -116,23 +101,15 @@ init() {
|
|||||||
|
|
||||||
# Set distro-specific functions
|
# Set distro-specific functions
|
||||||
case "$ID" in
|
case "$ID" in
|
||||||
fedora|centos)
|
fedora|centos) pkg_install(){ sudo "$RPM_MGR" install -y "$@"; } ;;
|
||||||
pkg_install(){ sudo "$RPM_MGR" install -y "$@"; }
|
debian|ubuntu) pkg_install(){ sudo apt-get install -y -q0 "$@"; } ;;
|
||||||
;;
|
suse) pkg_install(){ sudo zypper --non-interactive -q install --force --no-confirm "$@"; } ;;
|
||||||
debian|ubuntu)
|
arch) pkg_install(){ sudo pacman -S --noconfirm --needed "$@"; } ;;
|
||||||
pkg_install(){ sudo apt-get install -y -q0 "$@"; }
|
|
||||||
;;
|
|
||||||
suse)
|
|
||||||
pkg_install(){ sudo zypper --non-interactive -q install --force --no-confirm "$@"; }
|
|
||||||
;;
|
|
||||||
arch)
|
|
||||||
pkg_install(){ sudo pacman -S --noconfirm --needed "$@"; }
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
|
|
||||||
if hash axel &>/dev/null; then
|
if command -v axel &>/dev/null; then
|
||||||
DL_TOOL="axel"
|
DL_TOOL="axel"
|
||||||
elif hash curl &>/dev/null; then
|
elif command -v curl &>/dev/null; then
|
||||||
DL_TOOL="curl"
|
DL_TOOL="curl"
|
||||||
else
|
else
|
||||||
echo "Downloading the Image Builder requires axel or curl"
|
echo "Downloading the Image Builder requires axel or curl"
|
||||||
@@ -140,53 +117,27 @@ init() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
readInput() {
|
parse_input() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}" "$*"
|
||||||
|
|
||||||
unset RESET YES
|
|
||||||
|
|
||||||
declare -ga PROFILES
|
declare -ga PROFILES
|
||||||
declare long_opts='release:,version:,profile:,buildroot:,source,'
|
local long_opts='release:,version:,profile:,buildroot:,source,'
|
||||||
long_opts+='ssh-upgrade:,ssh-backup:,flash:,reset,yes,debug,help'
|
long_opts+='ssh-upgrade:,ssh-backup:,flash:,reset,yes,debug,help'
|
||||||
|
|
||||||
if _input=$(getopt -o +r:v:p:b:sf:ydh -l $long_opts -- "$@"); then
|
if _input=$(getopt -o +r:v:p:b:sf:ydh -l $long_opts -- "$@"); then
|
||||||
eval set -- "$_input"
|
eval set -- "$_input"
|
||||||
while true; do
|
while true; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
--release|-r|--version|-v)
|
--release|-r|--version|-v) shift; declare -g USER_RELEASE="$1" ;;
|
||||||
shift && declare -g USER_RELEASE="$1"
|
--profile|-p) shift; PROFILES+=("$1") ;;
|
||||||
;;
|
--buildroot|-b) shift; BUILDROOT="$1" ;;
|
||||||
--profile|-p)
|
--source|-s) FROM_SOURCE=1 ;;
|
||||||
shift && PROFILES+=("$1")
|
--ssh-upgrade) shift; SSH_UPGRADE_PATH="$1" ;;
|
||||||
;;
|
--ssh-backup) shift; SSH_BACKUP_PATH="$1" ;;
|
||||||
--buildroot|-b)
|
--flash|-f) shift; FLASH_DEV="$1" ;;
|
||||||
shift && BUILDROOT="$1"
|
--reset) RESET=1 ;;
|
||||||
;;
|
--yes|-y) YES=1 ;;
|
||||||
--source|-s)
|
--debug|-d) echo "Debugging on"; DEBUG=1 ;;
|
||||||
FROM_SOURCE=1
|
--help|-h) print_help; exit 0 ;;
|
||||||
;;
|
|
||||||
--ssh-upgrade)
|
|
||||||
shift && SSH_UPGRADE_PATH="$1"
|
|
||||||
;;
|
|
||||||
--ssh-backup)
|
|
||||||
shift && SSH_BACKUP_PATH="$1"
|
|
||||||
;;
|
|
||||||
--flash|-f)
|
|
||||||
shift && FLASH_DEV="$1"
|
|
||||||
;;
|
|
||||||
--reset)
|
|
||||||
RESET=1
|
|
||||||
;;
|
|
||||||
--yes|-y)
|
|
||||||
YES=1
|
|
||||||
;;
|
|
||||||
--debug|-d)
|
|
||||||
echo "Debugging on"
|
|
||||||
DEBUG=1
|
|
||||||
;;
|
|
||||||
--help|-h)
|
|
||||||
printHelp && exit 0
|
|
||||||
;;
|
|
||||||
--)
|
--)
|
||||||
shift
|
shift
|
||||||
break
|
break
|
||||||
@@ -196,19 +147,17 @@ readInput() {
|
|||||||
done
|
done
|
||||||
else
|
else
|
||||||
echo "Incorrect options provided"
|
echo "Incorrect options provided"
|
||||||
printHelp && exit 1
|
print_help; exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
install_dependencies() {
|
||||||
installDependencies() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
local lock_file="$BUILDROOT/.dependencies"
|
||||||
declare -a pkg_list
|
local -a pkg_list
|
||||||
declare lock_file="$BUILDROOT/.dependencies"
|
|
||||||
|
|
||||||
# TODO please contribute your platform here
|
# TODO please contribute your platform here
|
||||||
if (( FROM_SOURCE )); then
|
if ((FROM_SOURCE)); then
|
||||||
# For building from source with make
|
# For building from source with make
|
||||||
# https://openwrt.org/docs/guide-developer/toolchain/install-buildsystem
|
# https://openwrt.org/docs/guide-developer/toolchain/install-buildsystem
|
||||||
case "$ID" in
|
case "$ID" in
|
||||||
@@ -243,8 +192,7 @@ installDependencies() {
|
|||||||
"perl-JSON-PP"
|
"perl-JSON-PP"
|
||||||
"swig"
|
"swig"
|
||||||
"clang" # for qosify
|
"clang" # for qosify
|
||||||
"llvm15-libs"
|
"llvm15-libs")
|
||||||
)
|
|
||||||
;;
|
;;
|
||||||
debian|ubuntu)
|
debian|ubuntu)
|
||||||
pkg_list+=(
|
pkg_list+=(
|
||||||
@@ -263,8 +211,7 @@ installDependencies() {
|
|||||||
"unzip"
|
"unzip"
|
||||||
"zlib1g-dev"
|
"zlib1g-dev"
|
||||||
"file"
|
"file"
|
||||||
"wget"
|
"wget")
|
||||||
)
|
|
||||||
;;
|
;;
|
||||||
arch)
|
arch)
|
||||||
pkg_list+=(
|
pkg_list+=(
|
||||||
@@ -305,8 +252,7 @@ installDependencies() {
|
|||||||
"util-linux"
|
"util-linux"
|
||||||
"wget"
|
"wget"
|
||||||
"which"
|
"which"
|
||||||
"zlib"
|
"zlib")
|
||||||
)
|
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
debug "Skipping dependency install, your OS is unsupported"
|
debug "Skipping dependency install, your OS is unsupported"
|
||||||
@@ -331,8 +277,7 @@ installDependencies() {
|
|||||||
"python3"
|
"python3"
|
||||||
"python2"
|
"python2"
|
||||||
"axel"
|
"axel"
|
||||||
"perl-IPC-Cmd"
|
"perl-IPC-Cmd")
|
||||||
)
|
|
||||||
;;
|
;;
|
||||||
debian|ubuntu)
|
debian|ubuntu)
|
||||||
pkg_list+=(
|
pkg_list+=(
|
||||||
@@ -348,8 +293,7 @@ installDependencies() {
|
|||||||
"wget"
|
"wget"
|
||||||
"unzip"
|
"unzip"
|
||||||
"python"
|
"python"
|
||||||
"axel"
|
"axel")
|
||||||
)
|
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
debug "Skipping dependency install, your OS is unsupported"
|
debug "Skipping dependency install, your OS is unsupported"
|
||||||
@@ -365,40 +309,29 @@ installDependencies() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
getImageBuilder() {
|
get_imagebuilder() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}" "$*"
|
||||||
|
local -a ib_url_file=("$1" "$2")
|
||||||
|
local -a sha256_url_file=("$3" "$4")
|
||||||
|
local -a url_file_pairs=(
|
||||||
|
"${ib_url_file[@]}"
|
||||||
|
"${sha256_url_file[@]}")
|
||||||
|
|
||||||
local url="$1"
|
for ((i=0; i<${#url_file_pairs[@]}; i+=2)); do
|
||||||
|
local url="${url_file_pairs[i]}"
|
||||||
|
local file="${url_file_pairs[i+1]}"
|
||||||
|
|
||||||
if [[ -f "$IB_ARCHIVE" ]]; then
|
if [[ -f $file ]] && ask_ok "$file exists. Re-download?"; then
|
||||||
if askOk "$IB_ARCHIVE exists. Re-download?"; then
|
execute rm -f "$file"
|
||||||
execute rm -f "$IB_ARCHIVE"
|
|
||||||
else
|
|
||||||
return 0
|
|
||||||
fi
|
fi
|
||||||
|
if ! [[ -f "$file" ]]; then
|
||||||
|
echo "Downloading $url to $file using $DL_TOOL"
|
||||||
|
execute "$DL_TOOL" "-o" "$file" "$url"
|
||||||
fi
|
fi
|
||||||
|
done
|
||||||
echo "Downloading Image Builder archive using $DL_TOOL"
|
|
||||||
execute "$DL_TOOL" "-o" "$IB_ARCHIVE" "$url"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
getImageBuilderChecksum() {
|
add_repos() {
|
||||||
debug "${FUNCNAME[0]}"
|
|
||||||
|
|
||||||
if [[ -f $IB_SHA256_FILE ]]; then
|
|
||||||
if askOk "$IB_SHA256_FILE exists. Re-download?"; then
|
|
||||||
execute rm -f "$IB_SHA256_FILE"
|
|
||||||
else
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Downloading Image Builder checksum using $DL_TOOL"
|
|
||||||
"$DL_TOOL" "-o" "$IB_SHA256_FILE" "$IB_SHA256_URL"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
addRepos() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
if [[ -v P_ARR[repo] ]]; then
|
if [[ -v P_ARR[repo] ]]; then
|
||||||
@@ -409,18 +342,15 @@ addRepos() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ssh_backup() {
|
||||||
sshBackup() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
local date hostname backup_fname
|
||||||
declare date hostname backup_fname
|
|
||||||
|
|
||||||
[[ -d "$FILESDIR" ]] || mkdir -p "$FILESDIR"
|
|
||||||
|
|
||||||
printf -v date '%(%Y-%m-%d-%H-%M-%S)T'
|
printf -v date '%(%Y-%m-%d-%H-%M-%S)T'
|
||||||
hostname=$(ssh -qt "$SSH_BACKUP_PATH" echo -n \$HOSTNAME)
|
hostname=$(ssh -qt "$SSH_BACKUP_PATH" echo -n \$HOSTNAME)
|
||||||
backup_fname="backup-$hostname-$date.tar.gz"
|
backup_fname="backup-$hostname-$date.tar.gz"
|
||||||
|
|
||||||
|
[[ -d "$FILESDIR" ]] || execute mkdir -p "$FILESDIR"
|
||||||
|
|
||||||
# Make backup archive on remote
|
# Make backup archive on remote
|
||||||
if ! execute "ssh -t $SSH_BACKUP_PATH sysupgrade -b /tmp/$backup_fname"; then
|
if ! execute "ssh -t $SSH_BACKUP_PATH sysupgrade -b /tmp/$backup_fname"; then
|
||||||
echo "SSH backup failed"
|
echo "SSH backup failed"
|
||||||
@@ -442,13 +372,12 @@ sshBackup() {
|
|||||||
execute "rm $BUILDDIR/$backup_fname"
|
execute "rm $BUILDDIR/$backup_fname"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
make_images() {
|
||||||
makeImages() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
# Reuse the existing output
|
# Reuse the existing output
|
||||||
if [[ -d "$BINDIR" ]]; then
|
if [[ -d "$BINDIR" ]]; then
|
||||||
if askOk "$BINDIR exists. Rebuild?"; then
|
if ask_ok "$BINDIR exists. Rebuild?"; then
|
||||||
execute rm -rf "$BINDIR"
|
execute rm -rf "$BINDIR"
|
||||||
else
|
else
|
||||||
return 0
|
return 0
|
||||||
@@ -465,26 +394,21 @@ makeImages() {
|
|||||||
> "$BUILDDIR/make.log"
|
> "$BUILDDIR/make.log"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
verify_images() {
|
||||||
verifyImages() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
local outfile
|
||||||
declare outfile
|
|
||||||
|
|
||||||
for outfile in "$BINDIR"/*.img.gz; do
|
for outfile in "$BINDIR"/*.img.gz; do
|
||||||
verify "$outfile" "$IB_OUT_SHA256_FILE" || return 1
|
verify "$outfile" "$IB_OUT_SHA256_FILE" || return 1
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
flash_images() {
|
||||||
flashImage() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
local img_gz="$1"
|
||||||
declare img_gz="$1"
|
local dev="$2"
|
||||||
declare dev="$2"
|
local img="${img_gz%.gz}"
|
||||||
|
local partitions
|
||||||
declare img="${img_gz%.gz}"
|
|
||||||
declare partitions
|
|
||||||
|
|
||||||
if [[ ! -e "$dev" ]]; then
|
if [[ ! -e "$dev" ]]; then
|
||||||
echo "The device specified by --flash could not be found"
|
echo "The device specified by --flash could not be found"
|
||||||
@@ -500,7 +424,7 @@ flashImage() {
|
|||||||
execute gunzip -qfk "$img_gz"
|
execute gunzip -qfk "$img_gz"
|
||||||
|
|
||||||
echo "Unmounting target device $dev partitions"
|
echo "Unmounting target device $dev partitions"
|
||||||
partitions=( "$dev"?* )
|
partitions=("$dev"?*)
|
||||||
execute sudo umount "${partitions[@]}"
|
execute sudo umount "${partitions[@]}"
|
||||||
|
|
||||||
if execute sudo dd if="$img" of="$dev" bs=2M conv=fsync; then
|
if execute sudo dd if="$img" of="$dev" bs=2M conv=fsync; then
|
||||||
@@ -508,18 +432,15 @@ flashImage() {
|
|||||||
echo "Image flashed sucessfully!"
|
echo "Image flashed sucessfully!"
|
||||||
else
|
else
|
||||||
echo "dd failed!"
|
echo "dd failed!"
|
||||||
exit 1
|
return 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ssh_upgrade() {
|
||||||
sshUpgrade() {
|
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
local img_gz="$1"
|
||||||
declare img_gz="$1"
|
local ssh_path="$2"
|
||||||
declare ssh_path="$2"
|
local img_fname="${img_gz##*/}"
|
||||||
|
|
||||||
declare img_fname="${img_gz##*/}"
|
|
||||||
|
|
||||||
if ! [[ -f $img_gz ]]; then
|
if ! [[ -f $img_gz ]]; then
|
||||||
echo "$img_gz is missing, check build output"
|
echo "$img_gz is missing, check build output"
|
||||||
@@ -541,14 +462,13 @@ sshUpgrade() {
|
|||||||
ssh "$ssh_path" "sysupgrade -F /tmp/$img_fname"
|
ssh "$ssh_path" "sysupgrade -F /tmp/$img_fname"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
from_source() {
|
||||||
fromSource() {
|
debug "${FUNCNAME[0]}" "$*"
|
||||||
debug "${FUNCNAME[0]}"
|
local seed_url="$1"
|
||||||
|
local src_url="https://github.com/openwrt/openwrt.git"
|
||||||
declare src_url="https://github.com/openwrt/openwrt.git"
|
local seed_file="$GITWORKTREEDIR/.config"
|
||||||
declare seed_file="$GITWORKTREEDIR/.config"
|
local pkg config commit seed_file wt_commit description
|
||||||
declare pkg config commit seed_file wt_commit description
|
local -a make_opts config_opts
|
||||||
declare -a make_opts config_opts
|
|
||||||
|
|
||||||
echo "Building from source is under development"
|
echo "Building from source is under development"
|
||||||
|
|
||||||
@@ -568,7 +488,7 @@ fromSource() {
|
|||||||
[0-9][0-9].[0-9][0-9].*)
|
[0-9][0-9].[0-9][0-9].*)
|
||||||
local branch="openwrt-${RELEASE%.*}"
|
local branch="openwrt-${RELEASE%.*}"
|
||||||
local tag="v$RELEASE"
|
local tag="v$RELEASE"
|
||||||
if askOk "Use $branch branch HEAD (y, recommended) or $tag tag (N)?"; then
|
if ask_ok "Use $branch branch HEAD (y, recommended) or $tag tag (N)?"; then
|
||||||
wt_commit="origin/$branch"
|
wt_commit="origin/$branch"
|
||||||
else
|
else
|
||||||
wt_commit="$tag"
|
wt_commit="$tag"
|
||||||
@@ -580,7 +500,6 @@ fromSource() {
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|
||||||
# TODO There's a bug in the make clean functions that seem to invoke a full make
|
# TODO There's a bug in the make clean functions that seem to invoke a full make
|
||||||
# if [[ -d "$GITWORKTREEDIR" ]]; then
|
# if [[ -d "$GITWORKTREEDIR" ]]; then
|
||||||
# execute git -C "$GITWORKTREEDIR" checkout "$wt_commit"
|
# execute git -C "$GITWORKTREEDIR" checkout "$wt_commit"
|
||||||
@@ -589,7 +508,6 @@ fromSource() {
|
|||||||
# execute git -C "$GITSRCDIR" worktree add --force --detach "$GITWORKTREEDIR" "$wt_commit"
|
# execute git -C "$GITSRCDIR" worktree add --force --detach "$GITWORKTREEDIR" "$wt_commit"
|
||||||
# fi
|
# fi
|
||||||
|
|
||||||
|
|
||||||
# To workaround bug, don't use make *clean, blow it away and start fresh
|
# To workaround bug, don't use make *clean, blow it away and start fresh
|
||||||
[[ -d "$GITWORKTREEDIR" ]] && execute rm -rf "$GITWORKTREEDIR"
|
[[ -d "$GITWORKTREEDIR" ]] && execute rm -rf "$GITWORKTREEDIR"
|
||||||
execute git -C "$GITSRCDIR" worktree add --force --detach "$GITWORKTREEDIR" "$wt_commit"
|
execute git -C "$GITSRCDIR" worktree add --force --detach "$GITWORKTREEDIR" "$wt_commit"
|
||||||
@@ -600,8 +518,8 @@ fromSource() {
|
|||||||
echo "Current commit hash: $commit"
|
echo "Current commit hash: $commit"
|
||||||
echo "Git worktree description: $description"
|
echo "Git worktree description: $description"
|
||||||
|
|
||||||
if (( DEBUG )); then
|
if ((DEBUG)); then
|
||||||
if (( YES )); then
|
if ((YES)); then
|
||||||
git --no-pager -C "$GITWORKTREEDIR" log -1
|
git --no-pager -C "$GITWORKTREEDIR" log -1
|
||||||
else
|
else
|
||||||
git -C "$GITWORKTREEDIR" log -1
|
git -C "$GITWORKTREEDIR" log -1
|
||||||
@@ -617,8 +535,8 @@ fromSource() {
|
|||||||
./scripts/feeds install -a -f
|
./scripts/feeds install -a -f
|
||||||
|
|
||||||
# Grab the release seed config
|
# Grab the release seed config
|
||||||
if ! execute curl -so "$seed_file" "$SEED_URL"; then
|
if ! execute "$DL_TOOL" "-o" "$seed_file" "$seed_url"; then
|
||||||
echo "Could not obtain $seed_file from $SEED_URL"
|
echo "Could not obtain $seed_file from $seed_url"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -673,7 +591,7 @@ fromSource() {
|
|||||||
# make distclean # compiled output, toolchain, build tools, .config, feeds, .ccache
|
# make distclean # compiled output, toolchain, build tools, .config, feeds, .ccache
|
||||||
|
|
||||||
# Make prep
|
# Make prep
|
||||||
(( DEBUG )) && make_opts+=("V=s")
|
((DEBUG)) && make_opts+=("V=s")
|
||||||
#execute make "${make_opts[@]}" "-j1" dirclean # TODO 'dirclean' has a bug that triggers menuconfig
|
#execute make "${make_opts[@]}" "-j1" dirclean # TODO 'dirclean' has a bug that triggers menuconfig
|
||||||
execute make "${make_opts[@]}" "-j1" defconfig
|
execute make "${make_opts[@]}" "-j1" defconfig
|
||||||
execute make "${make_opts[@]}" "-j1" download
|
execute make "${make_opts[@]}" "-j1" download
|
||||||
@@ -697,28 +615,28 @@ fromSource() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Generic helpers
|
# Generic helpers
|
||||||
debug() { (( DEBUG )) && echo "Debug: $*"; }
|
debug() { ((DEBUG)) && echo "Debug: $*"; }
|
||||||
askOk() {
|
ask_ok() {
|
||||||
(( YES )) && return
|
((YES)) && return
|
||||||
local r
|
local r
|
||||||
read -r -p "$* [y/N]: " r
|
read -r -p "$* [y/N]: " r
|
||||||
r=${r,,}
|
r=${r,,}
|
||||||
[[ "$r" =~ ^(yes|y)$ ]]
|
[[ "$r" =~ ^(yes|y)$ ]]
|
||||||
}
|
}
|
||||||
extract() {
|
extract() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}" "$*"
|
||||||
declare archive="$1"
|
local archive="$1"
|
||||||
declare out_dir="$2"
|
local out_dir="$2"
|
||||||
if ! execute tar -axf "$archive" -C "$out_dir" --strip-components 1; then
|
if ! execute tar -axf "$archive" -C "$out_dir" --strip-components 1; then
|
||||||
echo "Extraction failed"
|
echo "Extraction failed"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
verify() {
|
verify() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}" "$*"
|
||||||
declare file_to_check="$1"
|
local file_to_check="$1"
|
||||||
declare sumfile="$2"
|
local sumfile="$2"
|
||||||
declare checksum
|
local checksum
|
||||||
|
|
||||||
hash sha256sum &>/dev/null || return 1
|
hash sha256sum &>/dev/null || return 1
|
||||||
[[ -f $sumfile && -f $file_to_check ]] || return 1
|
[[ -f $sumfile && -f $file_to_check ]] || return 1
|
||||||
@@ -726,8 +644,8 @@ verify() {
|
|||||||
echo -n "$checksum $file_to_check" | sha256sum --check --status
|
echo -n "$checksum $file_to_check" | sha256sum --check --status
|
||||||
}
|
}
|
||||||
load() {
|
load() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}" "$*"
|
||||||
declare source_file="$1"
|
local source_file="$1"
|
||||||
# shellcheck disable=SC1090
|
# shellcheck disable=SC1090
|
||||||
[[ -f $source_file ]] && source "$source_file"
|
[[ -f $source_file ]] && source "$source_file"
|
||||||
}
|
}
|
||||||
@@ -739,15 +657,12 @@ execute() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
debug "${FUNCNAME[0]}"
|
debug "${FUNCNAME[0]}"
|
||||||
|
|
||||||
init
|
init
|
||||||
|
|
||||||
load "$SCRIPTDIR/profiles"
|
load "$SCRIPTDIR/profiles"
|
||||||
|
parse_input "$@"
|
||||||
readInput "$@"
|
|
||||||
|
|
||||||
# Fallback to SCRIPTDIR if BUILDROOT has not been set
|
# Fallback to SCRIPTDIR if BUILDROOT has not been set
|
||||||
declare -g BUILDROOT="${BUILDROOT:=$SCRIPTDIR}"
|
declare -g BUILDROOT="${BUILDROOT:=$SCRIPTDIR}"
|
||||||
@@ -760,21 +675,21 @@ main() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
for dir in "$BUILDROOT/src" "$BUILDROOT/bin"; do
|
for dir in "$BUILDROOT/src" "$BUILDROOT/bin"; do
|
||||||
[[ -d "$dir" ]] || mkdir -p "$dir"
|
[[ -d "$dir" ]] || execute mkdir -p "$dir"
|
||||||
done
|
done
|
||||||
|
|
||||||
# Allow --reset without a profile
|
# Allow --reset without a profile
|
||||||
if (( RESET )) && [[ ${#PROFILES} -lt 1 ]]; then
|
if ((RESET)) && [[ ${#PROFILES} -lt 1 ]]; then
|
||||||
for d in "$BUILDROOT/src" "$BUILDROOT/bin"; do
|
for d in "$BUILDROOT/src" "$BUILDROOT/bin"; do
|
||||||
askOk "Remove $d?" && execute rm -rf "$d"
|
ask_ok "Remove $d?" && execute rm -rf "$d"
|
||||||
done
|
done
|
||||||
exit $?
|
exit $?
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installDependencies
|
install_dependencies
|
||||||
|
|
||||||
for profile in "${PROFILES[@]}"; do
|
for profile in "${PROFILES[@]}"; do
|
||||||
debug "Starting profile: $profile"
|
debug "Running profile: $profile"
|
||||||
|
|
||||||
if [[ ! ${!profile@a} = A ]]; then
|
if [[ ! ${!profile@a} = A ]]; then
|
||||||
echo "Profile '$profile' does not exist"
|
echo "Profile '$profile' does not exist"
|
||||||
@@ -783,28 +698,19 @@ main() {
|
|||||||
|
|
||||||
# Store profile in P_ARR nameref
|
# Store profile in P_ARR nameref
|
||||||
declare -gn P_ARR="$profile"
|
declare -gn P_ARR="$profile"
|
||||||
|
|
||||||
# Load profile
|
|
||||||
declare -g FILESYSTEM="${P_ARR[filesystem]:="squashfs"}"
|
declare -g FILESYSTEM="${P_ARR[filesystem]:="squashfs"}"
|
||||||
declare -g TARGET="${P_ARR[target]}"
|
declare -g TARGET="${P_ARR[target]}"
|
||||||
declare -g DEVICE="${P_ARR[device]}"
|
declare -g DEVICE="${P_ARR[device]}"
|
||||||
declare -g PACKAGES="${P_ARR[packages]:-}"
|
declare -g PACKAGES="${P_ARR[packages]:-}"
|
||||||
|
|
||||||
# Release precedence: user input>profile>env>hardcode
|
|
||||||
declare -g RELEASE="${USER_RELEASE:=${P_ARR[release]:=$RELEASE}}"
|
declare -g RELEASE="${USER_RELEASE:=${P_ARR[release]:=$RELEASE}}"
|
||||||
|
|
||||||
# normalize release input
|
# normalize RELEASE
|
||||||
case "$RELEASE" in
|
case "$RELEASE" in
|
||||||
snapshot|latest|main|master) # normalize aliases
|
snapshot|latest|main|master) RELEASE="snapshot" ;;
|
||||||
RELEASE="snapshot"
|
v[0-9][0-9].[0-9][0-9].*) RELEASE="${RELEASE#v}" ;;
|
||||||
;;
|
[0-9][0-9].[0-9][0-9].*) ;;
|
||||||
v[0-9][0-9].[0-9][0-9].*) # tag to semantic
|
|
||||||
RELEASE="${RELEASE#v}"
|
|
||||||
;;
|
|
||||||
[0-9][0-9].[0-9][0-9].*)
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
if ! (( FROM_SOURCE )); then
|
if ! ((FROM_SOURCE)); then
|
||||||
echo "Error: Invalid release version format"
|
echo "Error: Invalid release version format"
|
||||||
echo "Use semantic version, tag, or 'snapshot'"
|
echo "Use semantic version, tag, or 'snapshot'"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -817,16 +723,6 @@ main() {
|
|||||||
declare -g BUILDDIR="$BUILDROOT/src/$profile/$RELEASE"
|
declare -g BUILDDIR="$BUILDROOT/src/$profile/$RELEASE"
|
||||||
declare -g BINDIR="$BUILDROOT/bin/$profile/$RELEASE"
|
declare -g BINDIR="$BUILDROOT/bin/$profile/$RELEASE"
|
||||||
|
|
||||||
if (( RESET )); then
|
|
||||||
if (( FROM_SOURCE )); then
|
|
||||||
[[ -d $GITWORKTREEDIR ]] && askOk "Remove $GITWORKTREEDIR?"
|
|
||||||
execute git worktree remove --force "$GITWORKTREEDIR"
|
|
||||||
execute rm -rf "$GITWORKTREEDIR"
|
|
||||||
elif [[ -d $BUILDDIR ]] && askOk "Remove $BUILDDIR?"; then
|
|
||||||
execute rm -rf "$BUILDDIR"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$RELEASE" == "snapshot" ]]; then
|
if [[ "$RELEASE" == "snapshot" ]]; then
|
||||||
declare url_prefix="https://downloads.openwrt.org/snapshots/targets/$TARGET"
|
declare url_prefix="https://downloads.openwrt.org/snapshots/targets/$TARGET"
|
||||||
declare url_filename="openwrt-imagebuilder-${TARGET//\//-}.Linux-x86_64.tar.zst"
|
declare url_filename="openwrt-imagebuilder-${TARGET//\//-}.Linux-x86_64.tar.zst"
|
||||||
@@ -837,70 +733,53 @@ main() {
|
|||||||
declare img_fname="openwrt-$RELEASE-${TARGET//\//-}-$DEVICE-$FILESYSTEM"
|
declare img_fname="openwrt-$RELEASE-${TARGET//\//-}-$DEVICE-$FILESYSTEM"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
declare ib_url="$url_prefix/$url_filename"
|
local ib_url="$url_prefix/$url_filename"
|
||||||
|
local ib_file="$BUILDDIR/$url_filename"
|
||||||
|
local ib_sha256_url="$url_prefix/sha256sums"
|
||||||
|
local ib_sha256_file="$BUILDDIR/sha256sums"
|
||||||
|
local seed_url="$url_prefix/config.buildinfo"
|
||||||
|
|
||||||
if (( FROM_SOURCE )); then
|
if ((FROM_SOURCE)); then
|
||||||
declare -g SYSUPGRADEIMGGZ="$BINDIR/targets/$img_fname-sysupgrade.img.gz"
|
declare -g SYSUPGRADEIMGGZ="$BINDIR/targets/$img_fname-sysupgrade.img.gz"
|
||||||
declare -g SEED_URL="$url_prefix/config.buildinfo"
|
|
||||||
else
|
else
|
||||||
declare -g SYSUPGRADEIMGGZ="$BUILDDIR/$img_fname-sysupgrade.img.gz"
|
declare -g SYSUPGRADEIMGGZ="$BUILDDIR/$img_fname-sysupgrade.img.gz"
|
||||||
declare -g IB_ARCHIVE="$BUILDDIR/$url_filename"
|
|
||||||
declare -g IB_SHA256_URL="$url_prefix/sha256sums"
|
|
||||||
declare -g IB_SHA256_FILE="$IB_ARCHIVE.sha256sums"
|
|
||||||
declare -g IB_OUT_SHA256_FILE="$BINDIR/sha256sums"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if (( DEBUG )); then
|
if ((RESET)); then
|
||||||
|
if ((FROM_SOURCE)); then
|
||||||
|
[[ -d $GITWORKTREEDIR ]] && ask_ok "Remove $GITWORKTREEDIR?"
|
||||||
|
execute git worktree remove --force "$GITWORKTREEDIR"
|
||||||
|
execute rm -rf "$GITWORKTREEDIR"
|
||||||
|
elif [[ -d $BUILDDIR ]] && ask_ok "Remove $BUILDDIR?"; then
|
||||||
|
execute rm -rf "$BUILDDIR"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ((DEBUG)); then
|
||||||
echo "Profile settings:"
|
echo "Profile settings:"
|
||||||
for x in "${!P_ARR[@]}"; do printf "%s=%s\n" "$x" "${P_ARR[$x]}"; done
|
for x in "${!P_ARR[@]}"; do printf "%s=%s\n" "$x" "${P_ARR[$x]}"; done
|
||||||
echo "Build settings:"
|
echo "Environement variables:"
|
||||||
cat <<- EOF
|
declare -p
|
||||||
PROFILE, P_ARR (should match)=$profile, ${!P_ARR}
|
|
||||||
BUILDROOT=$BUILDROOT
|
|
||||||
BUILDDIR=$BUILDDIR
|
|
||||||
GITSRCDIR=$GITSRCDIR
|
|
||||||
GITWORKTREEDIR=$GITWORKTREEDIR
|
|
||||||
BINDIR=$BINDIR
|
|
||||||
TARGET=$TARGET
|
|
||||||
DEVICE=$DEVICE
|
|
||||||
RELEASE=$RELEASE
|
|
||||||
FILESYSTEM=$FILESYSTEM
|
|
||||||
SYSUPGRADEIMGGZ=$SYSUPGRADEIMGGZ
|
|
||||||
ib_url=$ib_url
|
|
||||||
EOF
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if (( FROM_SOURCE )); then
|
if ((FROM_SOURCE)); then
|
||||||
fromSource || return $?
|
from_source "$seed_url" || return $?
|
||||||
else
|
else
|
||||||
[[ -d $BUILDDIR ]] || mkdir -p "$BUILDDIR"
|
[[ -d $BUILDDIR ]] || mkdir -p "$BUILDDIR"
|
||||||
getImageBuilder "$ib_url" &&
|
get_imagebuilder "$ib_url" "$ib_file" "$ib_sha256_url" "$ib_sha256_file" &&
|
||||||
getImageBuilderChecksum &&
|
verify "$ib_file" "$ib_sha256_file" &&
|
||||||
verify "$IB_ARCHIVE" "$IB_SHA256_FILE" &&
|
extract "$ib_file" "$BUILDDIR" || return $?
|
||||||
extract "$IB_ARCHIVE" "$BUILDDIR" || return $?
|
add_repos
|
||||||
addRepos
|
make_images &&
|
||||||
makeImages &&
|
verify_images
|
||||||
verifyImages
|
|
||||||
#copyFiles
|
#copyFiles
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[[ -v SSH_BACKUP_PATH ]] &&
|
[[ -v SSH_BACKUP_PATH ]] && ssh_backup
|
||||||
sshBackup
|
[[ -v SSH_UPGRADE_PATH ]] && ssh_upgrade "$SYSUPGRADEIMGGZ" "$SSH_UPGRADE_PATH"
|
||||||
[[ -v SSH_UPGRADE_PATH ]] &&
|
[[ -v FLASH_DEV ]] && flash_images "$SYSUPGRADEIMGGZ" "$FLASH_DEV"
|
||||||
sshUpgrade "$SYSUPGRADEIMGGZ" "$SSH_UPGRADE_PATH"
|
|
||||||
[[ -v FLASH_DEV ]] &&
|
|
||||||
flashImage "$SYSUPGRADEIMGGZ" "$FLASH_DEV"
|
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
main "$@"
|
main "$@"
|
||||||
exit
|
exit $?
|
||||||
|
|
||||||
|
|
||||||
# VM setup (for testing)
|
|
||||||
# sudo sgdisk -N 0 /dev/vda &&
|
|
||||||
# sudo mkfs.ext4 /dev/vda1
|
|
||||||
|
|
||||||
# mkdir ~/mnt
|
|
||||||
# sudo mount /dev/vda1 ~/mnt
|
|
||||||
# sudo chown liveuser:liveuser -R ~/mnt
|
|
||||||
Reference in New Issue
Block a user