492 lines
14 KiB
Plaintext
Executable File
492 lines
14 KiB
Plaintext
Executable File
# -*- Autoconf -*-
|
|
# Process this file with autoconf to produce a configure script.
|
|
|
|
AC_PREREQ([2.61])
|
|
AC_INIT([Icinga2Web], [1.0.0], [info@icinga.org])
|
|
AC_PREFIX_DEFAULT(/usr/local/icinga2-web)
|
|
|
|
if test "x$prefix" = "xNONE" ; then
|
|
installDir="/usr/local/icinga2-web"
|
|
prefix=$installDir
|
|
else
|
|
installDir=$prefix
|
|
fi
|
|
|
|
# Checks for programs.
|
|
AC_PROG_INSTALL
|
|
AC_PROG_GREP
|
|
AC_PROG_SED
|
|
|
|
# Check for php
|
|
AC_ARG_VAR([PHP],[php cli binary])
|
|
AC_CHECK_PHP_INCLUDE([Zend/Application.php],[Zend Framework])
|
|
AC_CHECK_PHP_VERSION([5],[3],[0])
|
|
AC_CHECK_BIN([PHP], [php])
|
|
|
|
# Checks for libraries.
|
|
AC_CHECK_PHP_MODULE([sockets json])
|
|
|
|
#
|
|
# Configuration files
|
|
#
|
|
AC_ARG_WITH([icinga2web_config_path],
|
|
AS_HELP_STRING([--with-icinga2web-config-path], [Configuration path for icinga ]),
|
|
icinga2web_config_path="'$withval'",
|
|
icinga2web_config_path="'$prefix/config/'"
|
|
)
|
|
|
|
#
|
|
# Users for webfiles
|
|
#
|
|
|
|
AC_ARG_WITH([web_user],
|
|
AS_HELP_STRING([--with-web-user=USER], [username for web writable files (default www-data)]),
|
|
web_user=$withval,
|
|
AC_USER_GUESS([www wwwrun www-data apache httpd nobody],[web_user],[www-data])
|
|
)
|
|
|
|
AC_ARG_WITH([web_group],
|
|
AS_HELP_STRING([--with-web-group=GROUP], [group for web writable files (default www-data)]),
|
|
web_group=$withval,
|
|
AC_GROUP_GUESS([www www-data apache httpd nogroup nobody],[web_group], [www-data])
|
|
)
|
|
|
|
AC_ARG_WITH([web_path],
|
|
AS_HELP_STRING([--with-web-path=PATH], [web sub path (default /cranberry)]),
|
|
web_path=$withval,
|
|
web_path=/cranberry
|
|
)
|
|
|
|
AC_ARG_WITH([www_conf_path],
|
|
AS_HELP_STRING([--with-http-configuration-path=PATH], [Include folder apache2 (default /etc/apache2/conf.d)]),
|
|
www_conf_path=$withval,
|
|
www_conf_path=AC_PATH_GUESS([/etc/httpd/conf.d /etc/apache2/conf.d /etc/apache/conf.d], [www_conf_path], [/etc/apache2/conf.d])
|
|
)
|
|
|
|
#
|
|
# Users and groups for installation
|
|
#
|
|
|
|
AC_ARG_WITH([bin_user],
|
|
AS_HELP_STRING([--with-bin-user=USER], [user for all other files (default root)]),
|
|
bin_user=$withval,
|
|
bin_user=root
|
|
)
|
|
|
|
AC_ARG_WITH([bin_group],
|
|
AS_HELP_STRING([--with-bin-group=GROUP], [group for all other files (default bin)]),
|
|
bin_group=$withval,
|
|
bin_group=bin
|
|
)
|
|
|
|
#
|
|
# Internal database setup
|
|
#
|
|
|
|
AC_ARG_WITH([internal_db_type],
|
|
AS_HELP_STRING([--with-internal-db-type=TYPE], [database type to use for internal database (default mysql, supported: pgsql, mysql)]),
|
|
internal_db_type=$withval,
|
|
internal_db_type=mysql
|
|
)
|
|
|
|
AC_ARG_WITH([internal_db_name],
|
|
AS_HELP_STRING([--with-internal-db-name=NAME], [database name to use for internal database (default icinga2web)]),
|
|
internal_db_name=$withval,
|
|
internal_db_name=icinga2web
|
|
)
|
|
|
|
AC_ARG_WITH([internal_db_host],
|
|
AS_HELP_STRING([--with-internal-db-host=HOST], [database host to use for internal database (default localhost)]),
|
|
internal_db_host=$withval,
|
|
internal_db_host=localhost
|
|
)
|
|
|
|
AC_ARG_WITH([internal_db_port],
|
|
AS_HELP_STRING([--with-internal-db-port=PORT], [database port to use for internal database (default: 3306 for mysql, 5432 for pgsql)]),
|
|
internal_db_port=$withval,
|
|
internal_db_port=db_default_port
|
|
)
|
|
|
|
AC_ARG_WITH([internal_db_pass],
|
|
AS_HELP_STRING([--with-internal-db-pass=PASS], [database pass to use for internal database (default icinga2web)]),
|
|
internal_db_pass=$withval,
|
|
internal_db_pass=icinga2web
|
|
)
|
|
|
|
AC_ARG_WITH([internal_db_user],
|
|
AS_HELP_STRING([--with-internal-db-user=USER], [database user to use for internal database (default icinga2web)]),
|
|
internal_db_user=$withval,
|
|
internal_db_user=icinga2web
|
|
)
|
|
|
|
#
|
|
# Authorization method
|
|
#
|
|
|
|
AC_ARG_WITH([internal_authentication],
|
|
AC_HELP_STRING([--with-internal-authentication], [use the internal database for authentication (default: yes)]),
|
|
internal_authentication=yes,
|
|
internal_authentication=def
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_authentication],
|
|
AC_HELP_STRING([--with-ldap-authentication], [use a ldap server for authentication (default: no)]),
|
|
ldap_authentication=yes,
|
|
ldap_authentication=no
|
|
)
|
|
|
|
#
|
|
# LDAP Authorization
|
|
#
|
|
|
|
AC_ARG_WITH([ldap_host],
|
|
AS_HELP_STRING([--with-ldap-host=HOST], [host to use for authentication via ldap (default localhost)]),
|
|
ldap_host=$withval,
|
|
ldap_host=localhost
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_port],
|
|
AS_HELP_STRING([--with-ldap-port=PORT], [port to use for authentication via ldap (default 389)]),
|
|
ldap_port=$withval,
|
|
ldap_port=389
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_binddn],
|
|
AS_HELP_STRING([--with-ldap-binddn=DN], [dn to use for retrieving user information via ldap (default cn=admin, cn=config)]),
|
|
ldap_binddn=$withval,
|
|
ldap_binddn=["cn=Manager, ou=icinga, ou=org"]
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_bindpass],
|
|
AS_HELP_STRING([--with-ldap-bindpass=PASS], [password to use for retrieving user information via ldap (default admin)]),
|
|
ldap_bindpass=$withval,
|
|
ldap_bindpass=["secret"]
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_rootdn],
|
|
AS_HELP_STRING([--with-ldap-rootdn=LDAP_ATTRIBUTE], [root dn to use for user lookup (default ou=people, dc=icinga, dc=org)]),
|
|
ldap_rootdn=$withval,
|
|
ldap_rootdn=["ou=people, dc=icinga, dc=org"]
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_user_objectclass],
|
|
AS_HELP_STRING([--with-ldap-user-objectclass=LDAP_OBJECT_CLASS], [ldap object class to use for user authentication (default: inetOrgPerson)]),
|
|
ldap_user_objectclass=$withval,
|
|
ldap_user_objectclass="inetOrgPerson"
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_attribute_username],
|
|
AS_HELP_STRING([--with-ldap-attribute-username=LDAP_ATTRIBUTE], [user attribute to use for the username (default: uid)]),
|
|
ldap_attribute_username=$withval,
|
|
ldap_attribute_username="uid"
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_attribute_password],
|
|
AS_HELP_STRING([--with-ldap-attribute-password=LDAP_ATTRIBUTE], [user attribute to use for the password (default: password)]),
|
|
ldap_attribute_password=$withval,
|
|
ldap_attribute_password="password"
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_group_objectclass],
|
|
AS_HELP_STRING([--with-ldap-group-objectclass=LDAP_ATTRIBUTE], [ldap object type to use for group authentication (default: inetOrgPerson)]),
|
|
ldap_group_objectclass=$withval,
|
|
ldap_group_objectclass="group"
|
|
)
|
|
|
|
AC_ARG_WITH([ldap_attribute_groupname],
|
|
AS_HELP_STRING([--with-ldap-attribute-groupname=LDAP_OBJECT_CLASS], [user object type to use for the authentication (default: inetOrgPerson)]),
|
|
ldap_attribute_groupname=$withval,
|
|
ldap_attribute_groupname="guid"
|
|
)
|
|
|
|
#
|
|
# Icinga backend selection
|
|
#
|
|
|
|
AC_ARG_WITH([icinga_backend],
|
|
AS_HELP_STRING([--with-icinga-backend=(ido, statusdat, livestatus)], [backend to use for rb (default: statusdat)]),
|
|
icinga_backend=$withval,
|
|
icinga_backend="statusdat"
|
|
)
|
|
|
|
#
|
|
# Ido settings
|
|
#
|
|
|
|
AC_ARG_WITH([ido_db_type],
|
|
AS_HELP_STRING([--with-ido-db-type=(mysql, pgsql)], [database engine to use for retrieving data from the ido db (default: mysql)]),
|
|
ido_db_type=$withval,
|
|
ido_db_type="mysql"
|
|
)
|
|
|
|
AC_ARG_WITH([ido_host],
|
|
AS_HELP_STRING([--with-ido-host=HOST], [host to use for retrieving data from the ido db (default: localhost)]),
|
|
ido_host=$withval,
|
|
ido_host="localhost"
|
|
)
|
|
|
|
AC_ARG_WITH([ido_port],
|
|
AS_HELP_STRING([--with-ido-port=PORT], [backend to use for retrieving data from the ido db (default: 3306 for mysql. 5432 for pgsql)]),
|
|
ido_port=$withval,
|
|
ido_port=db_default_port
|
|
)
|
|
|
|
AC_ARG_WITH([ido_database],
|
|
AS_HELP_STRING([--with-ido-database=DATABASE], [database name to use for retrieving data from the ido db (default: icinga)]),
|
|
ido_database=$withval,
|
|
ido_database="icinga"
|
|
)
|
|
|
|
AC_ARG_WITH([ido_user],
|
|
AS_HELP_STRING([--with-ido-host=USER], [user to use for retrieving data from the ido db (default: icinga)]),
|
|
ido_user=$withval,
|
|
ido_user="icinga"
|
|
)
|
|
|
|
AC_ARG_WITH([ido_password],
|
|
AS_HELP_STRING([--with-ido-password=PASSWORD], [password to use for retrieving data from the ido db (default: icinga)]),
|
|
ido_password=$withval,
|
|
ido_password="icinga"
|
|
)
|
|
|
|
#
|
|
# Statusdat file location
|
|
#
|
|
|
|
AC_ARG_WITH([statusdat_file],
|
|
AS_HELP_STRING([--with-statusdat-file=FILE], [location of the status.dat file when retrieving data from status.dat (default: /usr/local/icinga/var/status.dat)]),
|
|
statusdat_file=$withval,
|
|
statusdat_file="/usr/local/icinga/var/status.dat"
|
|
)
|
|
|
|
AC_ARG_WITH([objects_cache_file],
|
|
AS_HELP_STRING([--with-objects-file=FILE], [location of the objects.cache file when retrieving data from status.dat (default: /usr/local/icinga/var/objects.cache)]),
|
|
objects_cache_file=$withval,
|
|
objects_cache_file="/usr/local/icinga/var/objects.cache"
|
|
)
|
|
|
|
#
|
|
# Livestatus connection
|
|
#
|
|
|
|
AC_ARG_WITH([livestatus_socket],
|
|
AS_HELP_STRING([--with-livestatus-socket=FILE], [location of the livestatus socket (default: /usr/local/icinga/var/rw/live)]),
|
|
livestatus_socket=$withval,
|
|
livestatus_socket="/usr/local/icinga/var/rw/live"
|
|
)
|
|
|
|
#
|
|
# Icinga commandpipe
|
|
#
|
|
|
|
AC_ARG_WITH([icinga_commandpipe],
|
|
AS_HELP_STRING([--with-icinga-commandpipe=FILE], [location of the command pipe used for sending commands (default: /usr/local/icinga/var/rw/icinga.cmd)]),
|
|
icinga_commandpipe=$withval,
|
|
icinga_commandpipe="/usr/local/icinga/var/rw/icinga.cmd"
|
|
)
|
|
|
|
AC_ARG_WITH([objects_cache_file],
|
|
AS_HELP_STRING([--with-objects-file=FILE], [location of the objects.cache file when retrieving data from status.dat (default: /usr/local/icinga/var/objects.cache)]),
|
|
objects_cache_file=$withval,
|
|
objects_cache_file="/usr/local/icinga/var/objects.cache"
|
|
)
|
|
|
|
#
|
|
# Livestatus connection
|
|
#
|
|
|
|
AC_ARG_WITH([livestatus_socket],
|
|
AS_HELP_STRING([--with-livestatus-socket=FILE], [location of the livestatus socket (default: /usr/local/icinga/var/rw/live)]),
|
|
livestatus_socket=$withval,
|
|
livestatus_socket="/usr/local/icinga/var/rw/live"
|
|
)
|
|
|
|
#
|
|
# Icinga commandpipe
|
|
#
|
|
|
|
AC_ARG_WITH([icinga_commandpipe],
|
|
AS_HELP_STRING([--with-icinga-commandpipe=FILE], [location of the command pipe used for sending commands (default: /usr/local/icinga/var/rw/icinga.cmd)]),
|
|
icinga_commandpipe=$withval,
|
|
icinga_commandpipe="/usr/local/icinga/var/rw/icinga.cmd"
|
|
)
|
|
|
|
# Installation options
|
|
INSTALL_OPTS="-o $bin_user -g $bin_group"
|
|
INSTALL_OPTS_WEB="-o $web_user -g $web_group"
|
|
|
|
AS_IF([test "x$internal_db_type" = xmysql], [
|
|
AC_CHECK_PHP_INCLUDE([Zend/Db/Adapter/Pdo/Mysql.php],[Zend Framework - MySQL PDO Adapter])
|
|
AC_CHECK_PHP_MODULE([mysql])
|
|
AS_IF([test "x$internal_db_port" == xdb_default_port], [internal_db_port=3306])
|
|
])
|
|
|
|
AS_IF([test "x$ido_db_type" = xmysql], [
|
|
AC_CHECK_PHP_INCLUDE([Zend/Db/Adapter/Pdo/Mysql.php],[Zend Framework - MySQL PDO Adapter])
|
|
AC_CHECK_PHP_MODULE([mysql])
|
|
AS_IF([test "x$ido_port" = xdb_default_port], [ido_port=3306])
|
|
])
|
|
|
|
AS_IF([test "x$internal_db_type" = xpgsql], [
|
|
AC_CHECK_PHP_INCLUDE([Zend/Db/Adapter/Pdo/Pgsql.php],[Zend Framework - PostgreSQL PDO Adapter])
|
|
AC_CHECK_PHP_MODULE([pgsql])
|
|
AS_IF([test "x$internal_db_port" = xdb_default_port], [internal_db_port=5432])
|
|
])
|
|
|
|
AS_IF([test "x$ido_db_type" = xpgsql], [
|
|
AC_CHECK_PHP_INCLUDE([Zend/Db/Adapter/Pdo/Pgsql.php],[Zend Framework - PostgreSQL PDO Adapter])
|
|
AC_CHECK_PHP_MODULE([pgsql])
|
|
AS_IF([test "x$ido_port" = xdb_default_port], [ido_port=5432])
|
|
])
|
|
|
|
#
|
|
# Comment out the disabled backends per default
|
|
#
|
|
|
|
ido_enabled="disable=1"
|
|
statusdat_enabled="disable=1"
|
|
livestatus_enabled="disable=1"
|
|
ldap_enabled="disable=1"
|
|
|
|
AS_CASE([$icinga_backend],
|
|
["ido"], [ido_enabled=""],
|
|
["statusdat"], [statusdat_enabled=""],
|
|
["livestatus"], [livestatus_enabled=""],
|
|
[statusdat_enabled=""])
|
|
|
|
AS_IF([test "x$ldap_authentication" != xno],
|
|
AC_CHECK_PHP_MODULE([ldap])
|
|
ldap_enabled=""
|
|
)
|
|
|
|
#
|
|
# Substitution variables
|
|
#
|
|
|
|
# Installation directives
|
|
AC_SUBST(app_name)
|
|
AC_SUBST(web_user)
|
|
AC_SUBST(web_group)
|
|
AC_SUBST(web_path)
|
|
AC_SUBST(www_conf_path)
|
|
AC_SUBST(bin_user)
|
|
AC_SUBST(bin_group)
|
|
AC_SUBST(icinga2web_config_path)
|
|
|
|
# Internal db setup
|
|
AC_SUBST(internal_db_type)
|
|
AC_SUBST(internal_db_name)
|
|
AC_SUBST(internal_db_host)
|
|
AC_SUBST(internal_db_port)
|
|
AC_SUBST(internal_db_user)
|
|
AC_SUBST(internal_db_pass)
|
|
|
|
# ldap setup
|
|
AC_SUBST(ldap_host)
|
|
AC_SUBST(ldap_port)
|
|
AC_SUBST(ldap_rootdn)
|
|
AC_SUBST(ldap_binddn)
|
|
AC_SUBST(ldap_bindpass)
|
|
AC_SUBST(ldap_user_objectclass)
|
|
AC_SUBST(ldap_attribute_basedn)
|
|
AC_SUBST(ldap_attribute_username)
|
|
AC_SUBST(ldap_attribute_password)
|
|
AC_SUBST(ldap_group_objectclass)
|
|
AC_SUBST(ldap_attribute_groupname)
|
|
|
|
# backend setup
|
|
AC_SUBST(icinga_backend)
|
|
|
|
# ido backend variables
|
|
AC_SUBST(ido_db_type)
|
|
AC_SUBST(ido_host)
|
|
AC_SUBST(ido_port)
|
|
AC_SUBST(ido_database)
|
|
AC_SUBST(ido_user)
|
|
AC_SUBST(ido_password)
|
|
|
|
# status.dat backend
|
|
AC_SUBST(statusdat_file)
|
|
AC_SUBST(objects_cache_file)
|
|
|
|
# livestatus backend
|
|
AC_SUBST(livestatus_socket)
|
|
|
|
# command pipe
|
|
AC_SUBST(icinga_commandpipe)
|
|
|
|
# Comment placeholders for toggling backends
|
|
AC_SUBST(livestatus_enabled)
|
|
AC_SUBST(statusdat_enabled)
|
|
AC_SUBST(ido_enabled)
|
|
AC_SUBST(ldap_enabled)
|
|
|
|
# Internal db setup
|
|
AC_SUBST(internal_db_type)
|
|
AC_SUBST(internal_db_name)
|
|
AC_SUBST(internal_db_host)
|
|
AC_SUBST(internal_db_port)
|
|
AC_SUBST(internal_db_user)
|
|
AC_SUBST(internal_db_pass)
|
|
|
|
# ldap setup
|
|
AC_SUBST(ldap_host)
|
|
AC_SUBST(ldap_port)
|
|
AC_SUBST(ldap_rootdn)
|
|
AC_SUBST(ldap_binddn)
|
|
AC_SUBST(ldap_bindpass)
|
|
AC_SUBST(ldap_user_objectclass)
|
|
AC_SUBST(ldap_attribute_basedn)
|
|
AC_SUBST(ldap_attribute_username)
|
|
AC_SUBST(ldap_attribute_password)
|
|
AC_SUBST(ldap_group_objectclass)
|
|
AC_SUBST(ldap_attribute_groupname)
|
|
|
|
# backend setup
|
|
AC_SUBST(icinga_backend)
|
|
|
|
# ido backend variables
|
|
AC_SUBST(ido_db_type)
|
|
AC_SUBST(ido_host)
|
|
AC_SUBST(ido_port)
|
|
AC_SUBST(ido_database)
|
|
AC_SUBST(ido_user)
|
|
AC_SUBST(ido_password)
|
|
|
|
# status.dat backend
|
|
AC_SUBST(statusdat_file)
|
|
AC_SUBST(objects_cache_file)
|
|
|
|
# livestatus backend
|
|
AC_SUBST(livestatus_socket)
|
|
|
|
# command pipe
|
|
AC_SUBST(icinga_commandpipe)
|
|
|
|
# Comment placeholders for toggling backends
|
|
AC_SUBST(livestatus_enabled)
|
|
AC_SUBST(statusdat_enabled)
|
|
AC_SUBST(ido_enabled)
|
|
AC_SUBST(ldap_enabled)
|
|
|
|
# Application and installation
|
|
AC_SUBST(PHP)
|
|
AC_SUBST(INSTALL_OPTS)
|
|
AC_SUBST(INSTALL_OPTS_WEB)
|
|
|
|
#
|
|
# Create config files
|
|
#
|
|
AC_CONFIG_FILES([
|
|
Makefile
|
|
config/authentication.ini
|
|
config/resources.ini
|
|
config/modules/monitoring/backends.ini
|
|
public/index.php
|
|
])
|
|
|
|
#
|
|
# Commit and write
|
|
#
|
|
AC_OUTPUT
|