aboutsummaryrefslogtreecommitdiffstats
path: root/contrib
diff options
context:
space:
mode:
authortilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2008-05-12 20:34:38 +0000
committertilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2008-05-12 20:34:38 +0000
commitf9717297bb3a0b198395952f36f50874d79db4e7 (patch)
treed638020922985178959bdd226ef01b0ba6f1eb71 /contrib
parent0feeda5c8f3b39b34b13b6a3b2c99034a5c670ca (diff)
Add a script which installs every package needed for a Debian install of
Asterisk, and includes possible support (to be contributed) for various other distributions. (closes issue #10523) Reported by: tzafrir Patches: install_prereq_2 uploaded by tzafrir (license 46) git-svn-id: http://svn.digium.com/svn/asterisk/trunk@115813 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'contrib')
-rwxr-xr-xcontrib/scripts/install_prereq126
1 files changed, 126 insertions, 0 deletions
diff --git a/contrib/scripts/install_prereq b/contrib/scripts/install_prereq
new file mode 100755
index 000000000..8770b9f59
--- /dev/null
+++ b/contrib/scripts/install_prereq
@@ -0,0 +1,126 @@
+#! /bin/sh
+#
+# $Id$
+#
+
+# install_prereq: a script to install distribution-specific
+# prerequirements
+
+set -e
+
+usage() {
+ echo "$0: a script to install distribution-specific prerequirement"
+ echo 'Revision: $Id$'
+ echo ""
+ echo "Usage: $0: Shows this message."
+ echo "Usage: $0 test Prints commands it is about to run."
+ echo "Usage: $0 install Really install."
+}
+
+# Basic build system:
+PACKAGES_DEBIAN="build-essential"
+# Asterisk: basic requirements:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libncurses-dev libz-dev libssl-dev"
+# Asterisk: very useful addons:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libcurl-dev libspeex-dev libogg-dev libvorbis-dev libasound2-dev"
+# Asterisk: nice-to-have addons:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libpq-dev unixodbc-dev libsqlite-dev"
+# Not so nice addon:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libopenh323-dev"
+# Extras for 1.4:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libsnmp-dev libiksemel-dev "
+
+PACKAGES_RH="gcc gcc-c++ ncurses-devel openssl-devel"
+
+KVERS=`uname -r`
+
+case "$1" in
+test) testcmd=echo ;;
+install) testcmd='' ;;
+'') usage; exit 0 ;;
+*) usage; exit 1 ;;
+esac
+
+in_test_mode() {
+ test "$testcmd" != ''
+}
+
+# Fixme: should be done by apt and not by dpkg?
+check_installed_debs() {
+ dpkg-query -W --showformat '${Status} ${Package}\n' "$@" 2>/dev/null \
+ | awk '/ not-installed/{print $4}'
+}
+
+# parsing the output of yum is close to impossible.
+# We'll use rpm and hope for the best:
+check_installed_rpms() {
+ for pack in "$@"
+ do
+ if ! rpm -q $pack >/dev/null 2>/dev/null
+ then echo $pack
+ fi
+ done
+}
+
+handle_debian() {
+ # echo "# Distribution is Debian or compatible"
+ extra_packs=`check_installed_debs $PACKAGES_DEBIAN`
+ $testcmd apt-get install -y $extra_packs
+}
+
+handle_rh() {
+ # echo "# Distribution is RedHat-based or compatible"
+ extra_packs=`check_installed_rpms $PACKAGES_RH`
+ # FIXME: is there yum with RHEL 4?
+ $testcmd yum install -y $extra_packs
+}
+
+if in_test_mode; then
+ echo "#############################################"
+ echo "## $1: test mode."
+ echo "## Use the commands here to install your system."
+ echo "#############################################"
+fi
+
+OS=`uname -s`
+unsupported_distro=''
+
+# A number of distributions we don't (yet?) support.
+if [ "$OS" != 'Linux' ]; then
+ echo >&2 "$0: Your OS ($OS) is currently not supported. Aborting."
+ exit 1
+fi
+
+if [ -f /etc/gentoo-release ]; then
+ unsupported_distro='Gentoo'
+fi
+
+if [ -f /etc/mandrake-release ]; then
+ unsupported_distro='Mandriva'
+fi
+
+if [ -f /etc/SuSE-release ]; then
+ unsupported_distro='SUSE'
+fi
+
+if [ -f /etc/slackware-version ]; then
+ unsupported_distro='Slackware'
+fi
+
+if [ "$unsupported_distro" != '' ]; then
+ echo >&2 "$0: Your distribution ($unsupported_distro) is currently not supported. Aborting."
+ exit 1
+fi
+
+# The distributions we do support:
+if [ -r /etc/debian_version ]; then
+ handle_debian
+elif [ -r /etc/redhat-release ]; then
+ handle_rh
+fi
+
+if ! in_test_mode; then
+ echo "#############################################"
+ echo "## $1 completed successfully"
+ echo "#############################################"
+fi