diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 14:11:00 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 14:11:00 +0000 |
commit | af754e596a8dbb05ed8580c342e7fe02e08b28e0 (patch) | |
tree | b2f334c2b55ede42081aa6710a72da784547d8ea /src/modules/rlm_couchbase/configure.ac | |
parent | Initial commit. (diff) | |
download | freeradius-af754e596a8dbb05ed8580c342e7fe02e08b28e0.tar.xz freeradius-af754e596a8dbb05ed8580c342e7fe02e08b28e0.zip |
Adding upstream version 3.2.3+dfsg.upstream/3.2.3+dfsg
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/modules/rlm_couchbase/configure.ac')
-rw-r--r-- | src/modules/rlm_couchbase/configure.ac | 220 |
1 files changed, 220 insertions, 0 deletions
diff --git a/src/modules/rlm_couchbase/configure.ac b/src/modules/rlm_couchbase/configure.ac new file mode 100644 index 0000000..453b92a --- /dev/null +++ b/src/modules/rlm_couchbase/configure.ac @@ -0,0 +1,220 @@ +AC_PREREQ([2.69]) +AC_INIT +AC_CONFIG_SRCDIR([rlm_couchbase.c]) +AC_REVISION($Revision$) +FR_INIT_MODULE([rlm_couchbase]) + +FR_MODULE_START_TESTS + +AC_PROG_CC +AC_PROG_CPP + +dnl ############################################################ +dnl # Check for json-c +dnl ############################################################ + +dnl extra argument: --with-jsonc-include-dir=DIR +jsonc_include_dir= +AC_ARG_WITH(jsonc-include-dir, + [AS_HELP_STRING([--with-jsonc-include-dir=DIR], + [Directory where the json-c includes may be found])], + [case "$withval" in + no) + AC_MSG_ERROR(Need jsonc-include-dir) + ;; + yes) + ;; + *) + jsonc_include_dir="$withval" + ;; + esac]) + +dnl extra argument: --with-jsonc-lib-dir=DIR +jsonc_lib_dir= +AC_ARG_WITH(jsonc-lib-dir, + [AS_HELP_STRING([--with-jsonc-lib-dir=DIR], + [Directory where the json-c libraries may be found])], + [case "$withval" in + no) + AC_MSG_ERROR(Need jsonc-lib-dir) + ;; + yes) + ;; + *) + jsonc_lib_dir="$withval" + ;; + esac]) + +dnl extra argument: --with-jsonc-dir=DIR +AC_ARG_WITH(jsonc-dir, + [AS_HELP_STRING([--with-jsonc-dir=DIR], + [Base directory where json-c is installed])], + [case "$withval" in + no) + AC_MSG_ERROR(Need json-c-dir) + ;; + yes) + ;; + *) + jsonc_lib_dir="$withval/lib" + jsonc_include_dir="$withval/include" + ;; + esac]) + +dnl ############################################################ +dnl # Check for json-c header files +dnl ############################################################ + +have_json="yes" +smart_try_dir="$jsonc_include_dir" +FR_SMART_CHECK_INCLUDE([json/json.h]) +if test "x$ac_cv_header_json_json_h" != "xyes"; then + FR_SMART_CHECK_INCLUDE([json-c/json.h]) + if test "x$ac_cv_header_jsonmc_json_h" != "xyes"; then + have_json="no" + AC_MSG_WARN([json-c headers not found. Use --with-jsonc-include-dir=<path>.]) + FR_MODULE_FAIL([json.h]) + else + AC_DEFINE([HAVE_JSONMC_JSON_H],[1],[json.h is at json-c/json.h relative to include dir]) + fi +else + AC_DEFINE([HAVE_JSON_JSON_H],[1],[json.h is at json/json.h relative to include dir]) +fi + +dnl ############################################################ +dnl # Check for json-c libraries +dnl ############################################################ + +smart_try_dir="$jsonc_lib_dir" +dnl # Use a json-c specific function which is only +dnl # available in newer versions. +FR_SMART_CHECK_LIB([json-c], [json_c_version]) +if test "x$ac_cv_lib_json_c_json_c_version" != "xyes"; then + dnl # Use a function which is included in legacy versions + dnl # but which may be available in other json libraries + FR_SMART_CHECK_LIB([json], [json_tokener_new]) + if test "x$ac_cv_lib_json_json_tokener_new" != "xyes"; then + have_json="no" + AC_MSG_WARN([json-c libraries not found. Use --with-jsonc-lib-dir=<path>.]) + FR_MODULE_FAIL([libjson-c]) + fi +fi + +if test "x$have_json" = "xyes"; then + dnl # Ensure we use the library we just found the rest of the checks + LDFLAGS="$SMART_LIBS" + + dnl # Add any optional functions here + AC_CHECK_FUNCS(\ + json_c_version \ + json_object_get_string_len \ + json_object_object_get_ex \ + json_object_new_int64 \ + json_tokener_error_desc \ + json_tokener_get_error + ) +else + FR_MODULE_FAIL([json-c]) +fi + +dnl ############################################################ +dnl # Check for libcouchbase +dnl ############################################################ + +dnl extra argument: --with-libcouchbase-include-dir=DIR +libcouchbase_include_dir= +AC_ARG_WITH(libcouchbase-include-dir, + [AS_HELP_STRING([--with-libcouchbase-include-dir=DIR], + [Directory where the libcouchbase includes may be found])], + [case "$withval" in + no) + AC_MSG_ERROR(Need libcouchbase-include-dir) + ;; + yes) + ;; + *) + libcouchbase_include_dir="$withval" + ;; + esac]) + +dnl extra argument: --with-libcouchbase-lib-dir=DIR +libcouchbase_lib_dir= +AC_ARG_WITH(libcouchbase-lib-dir, +[AS_HELP_STRING([--with-libcouchbase-lib-dir=DIR], + [Directory where the libcouchbase libraries may be found])], + [case "$withval" in + no) + AC_MSG_ERROR(Need libcouchbase-lib-dir) + ;; + yes) + ;; + *) + libcouchbase_lib_dir="$withval" + ;; + esac]) + +dnl extra argument: --with-libcouchbase-dir=DIR +AC_ARG_WITH(libcouchbase-dir, +[AS_HELP_STRING([--with-libcouchbase-dir=DIR], + [Base directory where libcouchbase is installed])], + [case "$withval" in + no) + AC_MSG_ERROR(Need libcouchbase-dir) + ;; + yes) + ;; + *) + libcouchbase_lib_dir="$withval/lib" + libcouchbase_include_dir="$withval/include" + ;; + esac]) + +dnl ############################################################ +dnl # Check for libcouchbase header files +dnl ############################################################ + +smart_try_dir="$libcouchbase_include_dir" +FR_SMART_CHECK_INCLUDE([libcouchbase/couchbase.h]) +if test "x$ac_cv_header_libcouchbase_couchbase_h" != "xyes"; then + AC_MSG_WARN([libcouchbase headers not found. Use --with-libcouchbase-include-dir=<path>.]) + FR_MODULE_FAIL([couchbase.h]) +fi + +dnl ############################################################ +dnl # Check for libcouchbase libraries +dnl ############################################################ + +smart_try_dir="$libcouchbase_lib_dir" +FR_SMART_CHECK_LIB([couchbase], [lcb_get_version]) +if test "x$ac_cv_lib_couchbase_lcb_get_version" != "xyes"; then + AC_MSG_WARN([libcouchbase libraries not found. Use --with-libcouchbase-lib-dir=<path>.]) + FR_MODULE_FAIL([libcouchbase]) +fi + +dnl ############################################################ +dnl # Check for OpenSSL +dnl ############################################################ + +AC_MSG_CHECKING(for OpenSSL support) +if test "x$OPENSSL_LIBS" != "x"; then + AC_MSG_RESULT(yes) +else + AC_MSG_RESULT(no) + FR_MODULE_FAIL([OpenSSL]) +fi + +dnl ############################################################ +dnl # Checks done - set targetname +dnl ############################################################ + +FR_MODULE_END_TESTS + +mod_ldflags="${SMART_LIBS}" +mod_cflags="${SMART_CPPFLAGS}" + +AC_SUBST(mod_cflags) +AC_SUBST(mod_ldflags) + +AC_CONFIG_HEADER([config.h]) +AC_CONFIG_FILES([all.mk]) +AC_OUTPUT |