summaryrefslogtreecommitdiffstats
path: root/packaging/installer/dependencies/alpine.sh
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 02:57:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 02:57:58 +0000
commitbe1c7e50e1e8809ea56f2c9d472eccd8ffd73a97 (patch)
tree9754ff1ca740f6346cf8483ec915d4054bc5da2d /packaging/installer/dependencies/alpine.sh
parentInitial commit. (diff)
downloadnetdata-upstream.tar.xz
netdata-upstream.zip
Adding upstream version 1.44.3.upstream/1.44.3upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rwxr-xr-xpackaging/installer/dependencies/alpine.sh114
1 files changed, 114 insertions, 0 deletions
diff --git a/packaging/installer/dependencies/alpine.sh b/packaging/installer/dependencies/alpine.sh
new file mode 100755
index 00000000..ee0504b3
--- /dev/null
+++ b/packaging/installer/dependencies/alpine.sh
@@ -0,0 +1,114 @@
+#!/bin/sh
+# Package tree used for installing netdata on distribution:
+# << Alpine: [3.12] [3.13] [3.14] [3.15] [edge] >>
+
+set -e
+
+NON_INTERACTIVE=0
+DONT_WAIT=0
+
+package_tree="
+ alpine-sdk
+ git
+ gcc
+ g++
+ automake
+ autoconf
+ cmake
+ make
+ libatomic
+ libtool
+ pkgconfig
+ tar
+ curl
+ gzip
+ libuv-dev
+ lz4-dev
+ openssl-dev
+ elfutils-dev
+ python3
+ zlib-dev
+ util-linux-dev
+ libmnl-dev
+ json-c-dev
+ musl-fts-dev
+ bison
+ flex
+ yaml-dev
+ "
+
+usage() {
+ cat << EOF
+OPTIONS:
+[--dont-wait] [--non-interactive] [ ]
+EOF
+}
+
+check_flags() {
+ while [ -n "${1}" ]; do
+ case "${1}" in
+ dont-wait | --dont-wait | -n)
+ DONT_WAIT=1
+ ;;
+
+ non-interactive | --non-interactive | -y)
+ NON_INTERACTIVE=1
+ ;;
+
+ help | -h | --help)
+ usage
+ exit 1
+ ;;
+ *)
+ echo >&2 "ERROR: Cannot understand option '${1}'"
+ echo >&2
+ usage
+ exit 1
+ ;;
+ esac
+ shift
+ done
+
+ if [ "${DONT_WAIT}" -eq 0 ] && [ "${NON_INTERACTIVE}" -eq 0 ]; then
+ printf "Press ENTER to run it > "
+ read -r || exit 1
+ fi
+}
+
+# shellcheck disable=2068
+check_flags ${@}
+
+packages_to_install=
+
+handle_old_alpine() {
+ version="$(grep VERSION_ID /etc/os-release | cut -f 2 -d '=')"
+ major="$(echo "${version}" | cut -f 1 -d '.')"
+ minor="$(echo "${version}" | cut -f 2 -d '.')"
+
+ if [ "${major}" -le 3 ] && [ "${minor}" -le 16 ]; then
+ package_tree="$(echo "${package_tree}" | sed 's/musl-fts-dev/fts-dev/')"
+ fi
+}
+
+for package in $package_tree; do
+ if apk -e info "$package" > /dev/null 2>&1 ; then
+ echo "Package '${package}' is installed"
+ else
+ echo "Package '${package}' is NOT installed"
+ packages_to_install="$packages_to_install $package"
+ fi
+done
+
+if [ -z "${packages_to_install}" ]; then
+ echo "All required packages are already installed. Skipping .."
+else
+ echo "packages_to_install:" "$packages_to_install"
+ opts="--force-broken-world"
+ if [ "${NON_INTERACTIVE}" -eq 1 ]; then
+ echo >&2 "Running in non-interactive mode"
+ else
+ opts="${opts} -i"
+ fi
+ # shellcheck disable=SC2086
+ apk add ${opts} $packages_to_install
+fi