|
@@ -1,4 +1,5 @@
|
|
#!/usr/bin/env bash
|
|
#!/usr/bin/env bash
|
|
|
|
+source ./functions.sh
|
|
|
|
|
|
#####################
|
|
#####################
|
|
##### DEFAULTS ######
|
|
##### DEFAULTS ######
|
|
@@ -6,7 +7,7 @@
|
|
|
|
|
|
setDefaults() {
|
|
setDefaults() {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
[[ -z $_debug ]] && _debug="true" # Set to true to enable debugging by default
|
|
[[ -z $_debug ]] && _debug="true" # Set to true to enable debugging by default
|
|
[[ -z $_builddir ]] && _builddir="$PWD"
|
|
[[ -z $_builddir ]] && _builddir="$PWD"
|
|
@@ -28,7 +29,7 @@ setDefaults() {
|
|
[[ -z $_version ]] && _version="snapshot"
|
|
[[ -z $_version ]] && _version="snapshot"
|
|
[[ -z $_target ]] && _target="bcm27xx/bcm2711"
|
|
[[ -z $_target ]] && _target="bcm27xx/bcm2711"
|
|
_packages+=("kmod-usb-net-asix-ax88179" "luci-app-upnp" "luci-app-wireguard" \
|
|
_packages+=("kmod-usb-net-asix-ax88179" "luci-app-upnp" "luci-app-wireguard" \
|
|
- "luci-app-vpn-policy-routing" "-dnsmasq" "dnsmasq-full")
|
|
|
|
|
|
+ "luci-app-vpn-policy-routing" "-dnsmasq" "dnsmasq-full" "luci-app-ddns")
|
|
fi
|
|
fi
|
|
}
|
|
}
|
|
|
|
|
|
@@ -36,9 +37,9 @@ setDefaults() {
|
|
##### FUNCTIONS #####
|
|
##### FUNCTIONS #####
|
|
#####################
|
|
#####################
|
|
|
|
|
|
-printHelpAndExit () {
|
|
|
|
|
|
+printHelpAndExit() {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
cat <<-'EOF'
|
|
cat <<-'EOF'
|
|
USAGE:
|
|
USAGE:
|
|
@@ -49,7 +50,7 @@ OPTIONS
|
|
--target, -t TARGET
|
|
--target, -t TARGET
|
|
--profile, -p PROFILE
|
|
--profile, -p PROFILE
|
|
--builddir, -b PATH
|
|
--builddir, -b PATH
|
|
- --ssh-backup SSH path
|
|
|
|
|
|
+ --ssh-upgrade SSH_PATH
|
|
Example: root@192.168.1.1
|
|
Example: root@192.168.1.1
|
|
--flash, -f DEVICE
|
|
--flash, -f DEVICE
|
|
Example: /dev/sdX
|
|
Example: /dev/sdX
|
|
@@ -61,11 +62,11 @@ EOF
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-parseInput () {
|
|
|
|
|
|
+parseInput() {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
- if _input=$(getopt -o +v:t:p:b:f:dh -l version:,target:,profile:,builddir:,ssh-backup:,flash:,debug,help -- "$@"); then
|
|
|
|
|
|
+ if _input=$(getopt -o +v:t:p:b:f:dh -l version:,target:,profile:,builddir:,ssh-upgrade:,flash:,debug,help -- "$@"); then
|
|
eval set -- "$_input"
|
|
eval set -- "$_input"
|
|
while true; do
|
|
while true; do
|
|
case "$1" in
|
|
case "$1" in
|
|
@@ -81,8 +82,8 @@ parseInput () {
|
|
--builddir|-b)
|
|
--builddir|-b)
|
|
shift && _builddir="$1"
|
|
shift && _builddir="$1"
|
|
;;
|
|
;;
|
|
- --ssh-backup)
|
|
|
|
- shift && _ssh_backup="$1"
|
|
|
|
|
|
+ --ssh-upgrade)
|
|
|
|
+ shift && _ssh_upgrade_path="$1"
|
|
;;
|
|
;;
|
|
--flash|-f)
|
|
--flash|-f)
|
|
shift && _flash_dev="$1"
|
|
shift && _flash_dev="$1"
|
|
@@ -108,19 +109,20 @@ parseInput () {
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-runDebug () { [[ "$_debug" == "true" ]] && echo "Running: " "$@" ; }
|
|
|
|
|
|
+debug () { [[ "$_debug" == "true" ]] && echo "Running: " "$@" ; }
|
|
|
|
|
|
|
|
|
|
-installPrerequisites () {
|
|
|
|
|
|
+setVars() {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
getOS () {
|
|
getOS () {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
if [[ -f /etc/os-release ]]; then
|
|
if [[ -f /etc/os-release ]]; then
|
|
source /etc/os-release
|
|
source /etc/os-release
|
|
|
|
+ export ID="$ID"
|
|
echo "Detected platform: $ID"
|
|
echo "Detected platform: $ID"
|
|
else
|
|
else
|
|
echo "Cannot detect OS!"
|
|
echo "Cannot detect OS!"
|
|
@@ -129,28 +131,45 @@ installPrerequisites () {
|
|
}
|
|
}
|
|
getOS
|
|
getOS
|
|
|
|
|
|
|
|
+ export _source_archive="$_builddir/sources/$_profile-$_version.tar.xz"
|
|
|
|
+ export _source_dir="${_source_archive%.tar.xz}"
|
|
|
|
+
|
|
|
|
+ export _out_bin_dir="$_builddir/bin/$_profile-$_version/"
|
|
|
|
+ export _out_bin_gz="$_out_bin_dir/openwrt-${_target//\//-}-$_profile-ext4-factory.img.gz"
|
|
|
|
+ export _out_bin="${_out_bin_gz%.gz}"
|
|
|
|
+
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+installPrerequisites() {
|
|
|
|
+
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
+
|
|
|
|
+ local -a _pkg_list
|
|
|
|
+ local _pkg_cmd
|
|
|
|
|
|
- echo "Installing dependencies..."
|
|
|
|
if [[ "$ID" == "fedora" ]]; then
|
|
if [[ "$ID" == "fedora" ]]; then
|
|
- if ! sudo dnf -y install @c-development @development-tools @development-libs zlib-static elfutils-libelf-devel gawk unzip file wget python3 python2 axel > /dev/null 2>&1; then
|
|
|
|
- echo "Warning: Problem installing prerequisites"
|
|
|
|
- fi
|
|
|
|
|
|
+ _pkg_list=("@c-development" "@development-tools" "@development-libs" "zlib-static" "elfutils-libelf-devel" "gawk" "unzip" "file" "wget" "python3" "python2" "axel")
|
|
|
|
+ _pkg_cmd="dnf"
|
|
elif [[ "$ID" =~ ^(debian|ubuntu)$ ]]; then
|
|
elif [[ "$ID" =~ ^(debian|ubuntu)$ ]]; then
|
|
- if ! sudo apt-get -y install build-essential libncurses5-dev libncursesw5-dev zlib1g-dev gawk git gettext libssl-dev xsltproc wget unzip python axel > /dev/null 2>&1; then
|
|
|
|
- echo "Warning: Problem installing prerequisites"
|
|
|
|
- fi
|
|
|
|
|
|
+ _pkg_list=("build-essential" "libncurses5-dev" "libncursesw5-dev" "zlib1g-dev" "gawk" "git" "gettext" "libssl-dev" "xsltproc" "wget" "unzip" "python" "axel")
|
|
|
|
+ _pkg_cmd="apt-get"
|
|
|
|
+ fi
|
|
|
|
+
|
|
|
|
+ echo "Installing dependencies"
|
|
|
|
+ debug "sudo $_pkg_cmd -y install ${_pkg_list[*]}"
|
|
|
|
+ if ! sudo "$_pkg_cmd" -y install "${_pkg_list[@]}" > /dev/null 2>&1; then
|
|
|
|
+ echo "Warning: Problem installing prerequisites"
|
|
|
|
+ return 1
|
|
fi
|
|
fi
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-acquireImageBuilder () {
|
|
|
|
|
|
+acquireImageBuilder() {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
local _url _filename
|
|
local _url _filename
|
|
- export _source_archive
|
|
|
|
-
|
|
|
|
- echo "Downloading image archive..."
|
|
|
|
|
|
|
|
if [[ "$_version" == "snapshot" ]]; then
|
|
if [[ "$_version" == "snapshot" ]]; then
|
|
_filename="openwrt-imagebuilder-${_target//\//-}.Linux-x86_64.tar.xz"
|
|
_filename="openwrt-imagebuilder-${_target//\//-}.Linux-x86_64.tar.xz"
|
|
@@ -163,67 +182,59 @@ acquireImageBuilder () {
|
|
# Make sources directory if it does not exist
|
|
# Make sources directory if it does not exist
|
|
[[ ! -d "$_builddir/sources" ]] && mkdir -p "$_builddir/sources"
|
|
[[ ! -d "$_builddir/sources" ]] && mkdir -p "$_builddir/sources"
|
|
|
|
|
|
- _source_archive="$_builddir/sources/$_profile-$_version.tar.xz"
|
|
|
|
-
|
|
|
|
# Remove existing ImageBuilder archives
|
|
# Remove existing ImageBuilder archives
|
|
[[ -f "$_source_archive" ]] && rm "$_source_archive"
|
|
[[ -f "$_source_archive" ]] && rm "$_source_archive"
|
|
|
|
|
|
- if ! axel -o "$_source_archive" "$_url"; then
|
|
|
|
|
|
+ echo "Downloading image archive"
|
|
|
|
+ debug "axel -o $_source_archive $_url"
|
|
|
|
+ if ! axel -o "$_source_archive" "$_url" > /dev/null 2>&1; then
|
|
echo "Could not download Image Builder"
|
|
echo "Could not download Image Builder"
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-extractImageBuilder () {
|
|
|
|
-
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+extractImageBuilder() {
|
|
|
|
|
|
- export _source_dir="${_source_archive%.tar.xz}"
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
[[ ! -d "$_source_dir" ]] && mkdir -p "$_source_dir"
|
|
[[ ! -d "$_source_dir" ]] && mkdir -p "$_source_dir"
|
|
|
|
|
|
- echo "Extracting image archive..."
|
|
|
|
- if [[ -f "$_source_archive" ]]; then
|
|
|
|
- if ! tar -xf "$_source_archive" -C "$_source_dir" --strip-components 1; then
|
|
|
|
- echo "Extraction failed"
|
|
|
|
- exit 1
|
|
|
|
- fi
|
|
|
|
|
|
+ if [[ ! -f "$_source_archive" ]]; then
|
|
|
|
+ echo "Archive missing"
|
|
|
|
+ exit 1
|
|
fi
|
|
fi
|
|
-}
|
|
|
|
|
|
|
|
|
|
+ echo "Extracting image archive"
|
|
|
|
+ debug "tar -xf $_source_archive -C $_source_dir --strip-components 1"
|
|
|
|
+ if ! tar -xf "$_source_archive" -C "$_source_dir" --strip-components 1; then
|
|
|
|
+ echo "Extraction failed"
|
|
|
|
+ exit 1
|
|
|
|
+ fi
|
|
|
|
+}
|
|
|
|
|
|
-makeImage () {
|
|
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
|
|
+makeImage() {
|
|
|
|
|
|
- export _out_bin_gz _out_bin_dir
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
# move to extracted source directory
|
|
# move to extracted source directory
|
|
if ! pushd "$_source_dir" > /dev/null 2>&1; then
|
|
if ! pushd "$_source_dir" > /dev/null 2>&1; then
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
|
|
- _out_bin_dir="$_builddir/bin/$_profile-$_version/"
|
|
|
|
-
|
|
|
|
# Make bin dir
|
|
# Make bin dir
|
|
[[ ! -d "$_out_bin_dir" ]] && mkdir -p "$_out_bin_dir"
|
|
[[ ! -d "$_out_bin_dir" ]] && mkdir -p "$_out_bin_dir"
|
|
|
|
|
|
# build image
|
|
# build image
|
|
echo "Running make -j4 image BIN_DIR=$_out_bin_dir PROFILE=$_profile PACKAGES=${_packages[*]} FILES=$_filesroot"
|
|
echo "Running make -j4 image BIN_DIR=$_out_bin_dir PROFILE=$_profile PACKAGES=${_packages[*]} FILES=$_filesroot"
|
|
|
|
+ debug "make -j4 image BIN_DIR=$_out_bin_dir PROFILE=$_profile PACKAGES=${_packages[*]} FILES=$_filesroot > make.log"
|
|
if ! make -j4 image BIN_DIR="$_out_bin_dir" PROFILE="$_profile" \
|
|
if ! make -j4 image BIN_DIR="$_out_bin_dir" PROFILE="$_profile" \
|
|
PACKAGES="${_packages[*]}" FILES="$_filesroot" > make.log; then
|
|
PACKAGES="${_packages[*]}" FILES="$_filesroot" > make.log; then
|
|
echo "Make image failed!"
|
|
echo "Make image failed!"
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
|
|
- _out_bin_gz="$_out_bin_dir/openwrt-${_target//\//-}-$_profile-ext4-factory.img.gz"
|
|
|
|
-
|
|
|
|
- if [[ ! -f "$_out_bin_gz" ]]; then
|
|
|
|
- echo "Make output image archive not found"
|
|
|
|
- exit 1
|
|
|
|
- fi
|
|
|
|
-
|
|
|
|
if ! popd > /dev/null 2>&1; then
|
|
if ! popd > /dev/null 2>&1; then
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
@@ -232,27 +243,20 @@ makeImage () {
|
|
|
|
|
|
flashImage() {
|
|
flashImage() {
|
|
|
|
|
|
- runDebug "${FUNCNAME[0]}"
|
|
|
|
-
|
|
|
|
- local _out_bin="${_out_bin_gz%.gz}"
|
|
|
|
-
|
|
|
|
- if [[ -f "$_out_bin_gz" ]]; then
|
|
|
|
- gunzip "$_out_bin_gz"
|
|
|
|
- fi
|
|
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
|
|
- if [[ ! -f "$_out_bin" ]]; then
|
|
|
|
- echo "Cannot find output bin file"
|
|
|
|
- exit 1
|
|
|
|
- fi
|
|
|
|
|
|
+ extractImage "$_out_bin_gz"
|
|
|
|
|
|
if [[ ! -d "$_flash_dev" ]]; then
|
|
if [[ ! -d "$_flash_dev" ]]; then
|
|
echo "The device specified by --flash could not be found"
|
|
echo "The device specified by --flash could not be found"
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
|
|
- echo "Unmounting target device $_flash_dev partitions..."
|
|
|
|
|
|
+ echo "Unmounting target device $_flash_dev partitions"
|
|
|
|
+ debug "umount $_flash_dev?*"
|
|
sudo umount "$_flash_dev?*"
|
|
sudo umount "$_flash_dev?*"
|
|
|
|
|
|
|
|
+ debug "sudo dd if=\"$_out_bin\" of=\"$_flash_dev\" bs=2M conv=fsync"
|
|
if sudo dd if="$_out_bin" of="$_flash_dev" bs=2M conv=fsync; then
|
|
if sudo dd if="$_out_bin" of="$_flash_dev" bs=2M conv=fsync; then
|
|
sync
|
|
sync
|
|
echo "Image flashed sucessfully!"
|
|
echo "Image flashed sucessfully!"
|
|
@@ -263,34 +267,37 @@ flashImage() {
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-#sshBackup () {
|
|
|
|
-#
|
|
|
|
-# runDebug "${FUNCNAME[0]}"
|
|
|
|
-#
|
|
|
|
-# # Make files directory if it does not exist
|
|
|
|
-# [[ ! -d "$_filesroot" ]] && mkdir -p "$_filesroot"
|
|
|
|
-#
|
|
|
|
-# for fd in "${_backedup[@]}"; do
|
|
|
|
-# _dir="${fd%/*}/"
|
|
|
|
-# [[ ! -d "$_filesroot$_dir" ]] && mkdir -p "$_filesroot/$_dir"
|
|
|
|
-# if ! scp -rp "$_ssh_backup:$fd" "$_filesroot/$_dir"; then
|
|
|
|
-# echo "Did not successfully backup files from --ssh-backup"
|
|
|
|
-# echo "Exiting now to prevent data loss!"
|
|
|
|
-# exit 1
|
|
|
|
-# fi
|
|
|
|
-# done
|
|
|
|
-#}
|
|
|
|
|
|
+sshUpgrade() {
|
|
|
|
+
|
|
|
|
+ debug "${FUNCNAME[0]}"
|
|
|
|
+
|
|
|
|
+ local _out_bin_gz_name="${_out_bin_gz##*/}"
|
|
|
|
+
|
|
|
|
+ echo "Copying upgrade image to $_ssh_upgrade_path"
|
|
|
|
+ debug "scp \"$_out_bin_gz\" \"$_ssh_upgrade_path:/tmp/$_out_bin_gz_name\""
|
|
|
|
+ # shellcheck disable=SC2140
|
|
|
|
+ if ! scp "$_out_bin_gz" "$_ssh_upgrade_path":"/tmp/$_out_bin_gz_name"; then
|
|
|
|
+ echo "Could not access the --ssh-upgrade PATH"
|
|
|
|
+ exit 1
|
|
|
|
+ fi
|
|
|
|
+
|
|
|
|
+ echo "Executing remote sysupgrade"
|
|
|
|
+ debug "ssh \"$_ssh_upgrade_path\" \"sysupgrade -F /tmp/$_out_bin_gz_name\""
|
|
|
|
+ # shellcheck disable=SC2029
|
|
|
|
+ ssh "$_ssh_upgrade_path" "sysupgrade -F /tmp/$_out_bin_gz_name"
|
|
|
|
+}
|
|
|
|
|
|
|
|
|
|
-__main () {
|
|
|
|
|
|
+__main() {
|
|
|
|
|
|
parseInput "$@"
|
|
parseInput "$@"
|
|
setDefaults
|
|
setDefaults
|
|
|
|
+ setVars
|
|
installPrerequisites
|
|
installPrerequisites
|
|
acquireImageBuilder
|
|
acquireImageBuilder
|
|
extractImageBuilder
|
|
extractImageBuilder
|
|
- #[[ -n $_ssh_backup ]] && sshBackup
|
|
|
|
makeImage
|
|
makeImage
|
|
|
|
+ [[ -n $_ssh_upgrade_path ]] && sshUpgrade
|
|
[[ -n $_flash_dev ]] && flashImage
|
|
[[ -n $_flash_dev ]] && flashImage
|
|
}
|
|
}
|
|
|
|
|