From 82f9bb2213fa7d4156f4527194a0117d3942f233 Mon Sep 17 00:00:00 2001 From: "Alan T. DeKok" Date: Thu, 30 Jan 2025 17:22:31 -0500 Subject: [PATCH] remove the couchbase module. It is old an unused by essentially anyone --- .../modules/installation/pages/upgrade.adoc | 7 +- doc/antora/modules/reference/nav.adoc | 1 - .../raddb/mods-available/all_modules.adoc | 2 - .../pages/raddb/mods-available/client.adoc | 2 +- .../pages/raddb/mods-available/couchbase.adoc | 260 - raddb/mods-available/client | 2 +- raddb/mods-available/couchbase | 258 - scripts/asciidoc/links.txt | 1 - scripts/osx/install_deps.sh | 1 - src/modules/rlm_couchbase/.gitignore | 1 - src/modules/rlm_couchbase/README.md | 9 - src/modules/rlm_couchbase/all.mk.in | 27 - src/modules/rlm_couchbase/config.h.in | 1 - src/modules/rlm_couchbase/configure | 5095 ----------------- src/modules/rlm_couchbase/configure.ac | 96 - src/modules/rlm_couchbase/couchbase.c | 421 -- src/modules/rlm_couchbase/couchbase.h | 107 - src/modules/rlm_couchbase/mod.c | 923 --- src/modules/rlm_couchbase/mod.h | 98 - src/modules/rlm_couchbase/rlm_couchbase.c | 565 -- 20 files changed, 8 insertions(+), 7869 deletions(-) delete mode 100644 doc/antora/modules/reference/pages/raddb/mods-available/couchbase.adoc delete mode 100644 raddb/mods-available/couchbase delete mode 100644 src/modules/rlm_couchbase/.gitignore delete mode 100644 src/modules/rlm_couchbase/README.md delete mode 100644 src/modules/rlm_couchbase/all.mk.in delete mode 100644 src/modules/rlm_couchbase/config.h.in delete mode 100755 src/modules/rlm_couchbase/configure delete mode 100644 src/modules/rlm_couchbase/configure.ac delete mode 100644 src/modules/rlm_couchbase/couchbase.c delete mode 100644 src/modules/rlm_couchbase/couchbase.h delete mode 100644 src/modules/rlm_couchbase/mod.c delete mode 100644 src/modules/rlm_couchbase/mod.h delete mode 100644 src/modules/rlm_couchbase/rlm_couchbase.c diff --git a/doc/antora/modules/installation/pages/upgrade.adoc b/doc/antora/modules/installation/pages/upgrade.adoc index 8f501badf0..1c01f08c48 100644 --- a/doc/antora/modules/installation/pages/upgrade.adoc +++ b/doc/antora/modules/installation/pages/upgrade.adoc @@ -683,7 +683,6 @@ The following modules will apply `connect_timeout`: * rlm_rest * rlm_linelog (network connections only) * rlm_ldap -* rlm_couchbase * rlm_cache_memcached * rlm_redis_* (all the redis modules) * rlm_sql_cassandra @@ -1052,6 +1051,12 @@ The `winbind` module uses an expansion `%winbind.group()` instead of The following modules have been deleted +=== rlm_couchbase + +This module used an old version of the Couchbase API, which is no +longer supported. Since no one stepped up to upgrade the module, it +has been removed. + === rlm_counter Instead of using this, please use the `sqlcounter` module with sqlite. diff --git a/doc/antora/modules/reference/nav.adoc b/doc/antora/modules/reference/nav.adoc index 691bf11bb1..963b98bd61 100644 --- a/doc/antora/modules/reference/nav.adoc +++ b/doc/antora/modules/reference/nav.adoc @@ -137,7 +137,6 @@ **** xref:raddb/mods-available/chap.adoc[CHAP module] **** xref:raddb/mods-available/cipher.adoc[Cipher] **** xref:raddb/mods-available/client.adoc[Client] -**** xref:raddb/mods-available/couchbase.adoc[Couchbase] **** xref:raddb/mods-available/csv.adoc[CSV] **** xref:raddb/mods-available/cui.adoc[CUI] **** xref:raddb/mods-available/date.adoc[Date] diff --git a/doc/antora/modules/reference/pages/raddb/mods-available/all_modules.adoc b/doc/antora/modules/reference/pages/raddb/mods-available/all_modules.adoc index cdd5dd43d0..fa2de8e534 100644 --- a/doc/antora/modules/reference/pages/raddb/mods-available/all_modules.adoc +++ b/doc/antora/modules/reference/pages/raddb/mods-available/all_modules.adoc @@ -43,8 +43,6 @@ Supports file attachments, size limited by the MTA. | xref:raddb/mods-available/cache.adoc[cache] | Stores attributes and/or lists and adds them back to a subsequent request or to the current request on a later execution of the module. | xref:raddb/mods-available/client.adoc[client] | Reads client definitions from flat files. -| xref:raddb/mods-available/couchbase.adoc[couchbase] | Allows attributes to be stored and retrieved from a couchbase server. Client definitions may also be bulk loaded from a -couchbase server as FreeRADIUS starts. | xref:raddb/mods-available/csv.adoc[csv] | Maps values in a CSV file to FreeRADIUS attributes and adds them to the request. | xref:raddb/mods-available/passwd.adoc[passwd] | Reads and caches line-oriented files that are in a format similar to ``/etc/passwd``. | xref:raddb/mods-available/redis.adoc[redis] | Provides connectivity to single and clustered instances of Redis. This module exposes a string expansion that may be diff --git a/doc/antora/modules/reference/pages/raddb/mods-available/client.adoc b/doc/antora/modules/reference/pages/raddb/mods-available/client.adoc index 7eb2ea629d..79f03be82e 100644 --- a/doc/antora/modules/reference/pages/raddb/mods-available/client.adoc +++ b/doc/antora/modules/reference/pages/raddb/mods-available/client.adoc @@ -12,7 +12,7 @@ client definitions from FreeRADIUS config files transforming them into attribute These attributes are then used by the server to create internal client definitions. This indirection is necessary as client definitions can be provided by many different -modules (`ldap`, `sql`, `couchbase` etc...), all of which emit client data in +modules (`ldap`, `sql`, etc...), all of which emit client data in attribute form. Treating static configuration files specially would increase code complexity. diff --git a/doc/antora/modules/reference/pages/raddb/mods-available/couchbase.adoc b/doc/antora/modules/reference/pages/raddb/mods-available/couchbase.adoc deleted file mode 100644 index 1397d8867f..0000000000 --- a/doc/antora/modules/reference/pages/raddb/mods-available/couchbase.adoc +++ /dev/null @@ -1,260 +0,0 @@ - - - - -= Couchbase Module - -The `couchbase` module is used to provide connections to a `link:https://www.couchbase.com/[Couchbase]` database. - - - -## Configuration Settings - - -server:: List of Couchbase hosts (hosts may be space, tab, comma or semicolon separated). -Ports are optional if servers are listening on the standard port. - -NOTE: Complete pool urls are preferred. - - - -bucket:: Couchbase bucket name. - - - -username:: Couchbase bucket username (optional). - - - -password:: Couchbase bucket password (optional). - - - -opts { ... }:: flags for libcouchbase (see Couchbase documentation). - -Set this to enable debugging, view timeouts, and all options -supported by `lcb_cntl_string()` from libcouchbase API. - -NOTE: These debugging options can produce significant amounts of logging output. - - - -acct_key:: Couchbase accounting document key. - -This key is dynamically expanded at run time. - - - -doctype:: Value for the 'docType' element in the json body for accounting documents. - - - -expire:: Accounting document expire time in seconds (0 = never). - - - -update { ... }:: Map attribute names to json element names for accounting. - -Configuration items are in the format ` = ''` - -NOTE: Element names should be *single quoted*. -Attributes not in this map will not be recorded. - - - -user_key:: Couchbase document key for user documents (`unlang` supported). - - - -read_clients:: Set to `yes` to read radius clients from the Couchbase view specified below. -NOTE: Clients will *ONLY* be read on server *startup*. - - - -client { ... }:: `Map` attribute names to jSON element names when loading clients. - -Configuration follows the same rules as the accounting `map` above. - - -view:: Couchbase view that should return all available client documents. - - - -template { ... }:: Sets default values (not obtained from couchbase) for new client entries. - - - -attribute { ... }:: Sets the client mappings following the format: ` = ''`. - -The following attributes are required: - -[options="header,autowidth"] -|=== -| Attr | Description -| `ipaddr`, `ipv4add`, `ipv6addr` | Client IP Address. -| `secret` | RADIUS shared secret. -|=== - -NOTE: All attributes usually supported in a `client` definition are also -supported here. Element names *should be single quoted*. - - - -pool { ... }:: The connection pool is new for >= `3.0`, and will be used in many -modules, for all kinds of connection-related activity. - - -start:: Connections to create during module instantiation. - -If the server cannot create specified number of -connections during instantiation it will exit. -Set to `0` to allow the server to start without the -external service being available. - - - -min:: Minimum number of connections to keep open. - - - -max:: Maximum number of connections. - -If these connections are all in use and a new one -is requested, the request will NOT get a connection. - -Setting `max` to *LESS* than the number of threads means -that some threads may starve, and you will see errors -like _No connections available and at max connection limit_. - -Setting `max` to MORE than the number of threads means -that there are more connections than necessary. - -If `max` is not specified, then it defaults to the number -of workers configured. - - - -spare:: Spare connections to be left idle. - -NOTE: Idle connections *WILL* be closed if `idle_timeout` -is set. This should be less than or equal to `max` above. - - - -uses:: Number of uses before the connection is closed. - -NOTE: `0` means "infinite". - - - -lifetime:: The lifetime (in seconds) of the connection. - -NOTE: A setting of `0` means infinite (no limit). - - - -idle_timeout:: The idle timeout (in seconds). A connection which is -unused for this length of time will be closed. - -NOTE: A setting of `0` means infinite (no timeout). - - - -connect_timeout:: Connection timeout (in seconds). The maximum amount of -time to wait for a new connection to be established. - - -[WARNING] -==== -All configuration settings are enforced. If a -connection is closed because of `idle_timeout`, -`uses`, or `lifetime`, then the total number of -connections *MAY* fall below `min`. When that -happens, it will open a new connection. It will -also log a *WARNING* message. - -The solution is to either lower the `min` connections, -or increase `lifetime`/`idle_timeout`. -==== - -== Default Configuration - -``` -couchbase { - server = "http://cb01.example.org:8091/ http://cb02.example.org:8091/" - bucket = "radius" -# username = "radius" -# password = "password" - opts { -# console_log_level = "5" -# console_log_file = "${logdir}/libcouchbase.log" -# send_hello = "false" -# detailed_errcodes = "true" - } - acct_key = "radacct_%{&Acct-Unique-Session-Id || &Acct-Session-Id}" - doctype = "radacct" - expire = 2592000 - update { - &Acct-Session-Id = 'sessionId' - &Acct-Unique-Session-Id = 'uniqueId' - &Acct-Status-Type = 'lastStatus' - &Acct-Authentic = 'authentic' - &User-Name = 'userName' - &Stripped-User-Name = 'strippedUserName' - &Stripped-User-Domain = 'strippedUserDomain' - &Realm = 'realm' - &NAS-IP-Address = 'nasIpAddress' - &NAS-Identifier = 'nasIdentifier' - &NAS-Port = 'nasPort' - &Called-Station-Id = 'calledStationId' - &Called-Station-SSID = 'calledStationSSID' - &Calling-Station-Id = 'callingStationId' - &Framed-Protocol = 'framedProtocol' - &Framed-IP-Address = 'framedIpAddress' - &NAS-Port-Type = 'nasPortType' - &Connect-Info = 'connectInfo' - &Acct-Session-Time = 'sessionTime' - &Acct-Input-Packets = 'inputPackets' - &Acct-Output-Packets = 'outputPackets' - &Acct-Input-Octets = 'inputOctets' - &Acct-Output-Octets = 'outputOctets' - &Acct-Input-Gigawords = 'inputGigawords' - &Acct-Output-Gigawords = 'outputGigawords' - &Event-Timestamp = 'lastUpdated' - } - user_key = "raduser_%md5(%tolower(%{&Stripped-User-Name || &User-Name}))" -# read_clients = no - client { - view = "_design/client/_view/by_id" - template { -# login = 'test' -# password = 'test' -# proto = tcp -# require_message_authenticator = yes - } - attribute { - ipaddr = 'clientIdentifier' - secret = 'clientSecret' - shortname = 'clientShortname' - nas_type = 'nasType' - virtual_server = 'virtualServer' - require_message_authenticator = 'requireMessageAuthenticator' - limit { - max_connections = 'maxConnections' - lifetime = 'clientLifetime' - idle_timeout = 'idleTimeout' - } - } - } - pool { - start = 0 - min = 0 -# max = - spare = 1 - uses = 0 - lifetime = 0 - idle_timeout = 1200 - connect_timeout = 3.0 - } -} -``` diff --git a/raddb/mods-available/client b/raddb/mods-available/client index dbe743d230..c7f14b35d7 100644 --- a/raddb/mods-available/client +++ b/raddb/mods-available/client @@ -15,7 +15,7 @@ # These attributes are then used by the server to create internal client definitions. # # This indirection is necessary as client definitions can be provided by many different -# modules (`ldap`, `sql`, `couchbase` etc...), all of which emit client data in +# modules (`ldap`, `sql`, etc...), all of which emit client data in # attribute form. Treating static configuration files specially would increase code # complexity. # diff --git a/raddb/mods-available/couchbase b/raddb/mods-available/couchbase deleted file mode 100644 index d5d84833ba..0000000000 --- a/raddb/mods-available/couchbase +++ /dev/null @@ -1,258 +0,0 @@ -# -*- text -*- -# -# -# $Id$ - -####################################################################### -# -# = Couchbase Module -# -# The `couchbase` module is used to provide connections to a `Couchbase` database. -# - -# -# ## Configuration Settings -# -couchbase { - # - # server:: List of Couchbase hosts (hosts may be space, tab, comma or semicolon separated). - # Ports are optional if servers are listening on the standard port. - # - # NOTE: Complete pool urls are preferred. - # - server = "http://cb01.example.org:8091/ http://cb02.example.org:8091/" - - # - # bucket:: Couchbase bucket name. - # - bucket = "radius" - - # - # username:: Couchbase bucket username (optional). - # -# username = "radius" - - # - # password:: Couchbase bucket password (optional). - # -# password = "password" - - # - # opts { ... }:: flags for libcouchbase (see Couchbase documentation). - # - # Set this to enable debugging, view timeouts, and all options - # supported by `lcb_cntl_string()` from libcouchbase API. - # - # NOTE: These debugging options can produce significant amounts of logging output. - # - opts { -# console_log_level = "5" -# console_log_file = "${logdir}/libcouchbase.log" -# send_hello = "false" -# detailed_errcodes = "true" - } - - # - # acct_key:: Couchbase accounting document key. - # - # This key is dynamically expanded at run time. - # - acct_key = "radacct_%{&Acct-Unique-Session-Id || &Acct-Session-Id}" - - # - # doctype:: Value for the 'docType' element in the json body for accounting documents. - # - doctype = "radacct" - - # - # expire:: Accounting document expire time in seconds (0 = never). - # - expire = 2592000 - - # - # update { ... }:: Map attribute names to json element names for accounting. - # - # Configuration items are in the format ` = ''` - # - # NOTE: Element names should be *single quoted*. - # Attributes not in this map will not be recorded. - # - update { - &Acct-Session-Id = 'sessionId' - &Acct-Unique-Session-Id = 'uniqueId' - &Acct-Status-Type = 'lastStatus' - &Acct-Authentic = 'authentic' - &User-Name = 'userName' - &Stripped-User-Name = 'strippedUserName' - &Stripped-User-Domain = 'strippedUserDomain' - &Realm = 'realm' - &NAS-IP-Address = 'nasIpAddress' - &NAS-Identifier = 'nasIdentifier' - &NAS-Port = 'nasPort' - &Called-Station-Id = 'calledStationId' - &Called-Station-SSID = 'calledStationSSID' - &Calling-Station-Id = 'callingStationId' - &Framed-Protocol = 'framedProtocol' - &Framed-IP-Address = 'framedIpAddress' - &NAS-Port-Type = 'nasPortType' - &Connect-Info = 'connectInfo' - &Acct-Session-Time = 'sessionTime' - &Acct-Input-Packets = 'inputPackets' - &Acct-Output-Packets = 'outputPackets' - &Acct-Input-Octets = 'inputOctets' - &Acct-Output-Octets = 'outputOctets' - &Acct-Input-Gigawords = 'inputGigawords' - &Acct-Output-Gigawords = 'outputGigawords' - &Event-Timestamp = 'lastUpdated' - } - - # - # user_key:: Couchbase document key for user documents (`unlang` supported). - # - user_key = "raduser_%md5(%tolower(%{&Stripped-User-Name || &User-Name}))" - - # - # read_clients:: Set to `yes` to read radius clients from the Couchbase view specified below. - # NOTE: Clients will *ONLY* be read on server *startup*. - # -# read_clients = no - - # - # client { ... }:: `Map` attribute names to jSON element names when loading clients. - # - # Configuration follows the same rules as the accounting `map` above. - # - client { - # - # view:: Couchbase view that should return all available client documents. - # - view = "_design/client/_view/by_id" - - # - # template { ... }:: Sets default values (not obtained from couchbase) for new client entries. - # - template { -# login = 'test' -# password = 'test' -# proto = tcp -# require_message_authenticator = yes - } - - # - # attribute { ... }:: Sets the client mappings following the format: ` = ''`. - # - # The following attributes are required: - # - # [options="header,autowidth"] - # |=== - # | Attr | Description - # | `ipaddr`, `ipv4add`, `ipv6addr` | Client IP Address. - # | `secret` | RADIUS shared secret. - # |=== - # - # NOTE: All attributes usually supported in a `client` definition are also - # supported here. Element names *should be single quoted*. - # - attribute { - ipaddr = 'clientIdentifier' - secret = 'clientSecret' - shortname = 'clientShortname' - nas_type = 'nasType' - virtual_server = 'virtualServer' - require_message_authenticator = 'requireMessageAuthenticator' - limit { - max_connections = 'maxConnections' - lifetime = 'clientLifetime' - idle_timeout = 'idleTimeout' - } - } - } - - # - # pool { ... }:: The connection pool is new for >= `3.0`, and will be used in many - # modules, for all kinds of connection-related activity. - # - pool { - # - # start:: Connections to create during module instantiation. - # - # If the server cannot create specified number of - # connections during instantiation it will exit. - # Set to `0` to allow the server to start without the - # external service being available. - # - start = 0 - - # - # min:: Minimum number of connections to keep open. - # - min = 0 - - # - # max:: Maximum number of connections. - # - # If these connections are all in use and a new one - # is requested, the request will NOT get a connection. - # - # Setting `max` to *LESS* than the number of threads means - # that some threads may starve, and you will see errors - # like _No connections available and at max connection limit_. - # - # Setting `max` to MORE than the number of threads means - # that there are more connections than necessary. - # - # If `max` is not specified, then it defaults to the number - # of workers configured. - # -# max = - - # - # spare:: Spare connections to be left idle. - # - # NOTE: Idle connections *WILL* be closed if `idle_timeout` - # is set. This should be less than or equal to `max` above. - # - spare = 1 - - # - # uses:: Number of uses before the connection is closed. - # - # NOTE: `0` means "infinite". - # - uses = 0 - - # - # lifetime:: The lifetime (in seconds) of the connection. - # - # NOTE: A setting of `0` means infinite (no limit). - # - lifetime = 0 - - # - # idle_timeout:: The idle timeout (in seconds). A connection which is - # unused for this length of time will be closed. - # - # NOTE: A setting of `0` means infinite (no timeout). - # - idle_timeout = 1200 - - # - # connect_timeout:: Connection timeout (in seconds). The maximum amount of - # time to wait for a new connection to be established. - # - connect_timeout = 3.0 - - # [WARNING] - # ==== - # All configuration settings are enforced. If a - # connection is closed because of `idle_timeout`, - # `uses`, or `lifetime`, then the total number of - # connections *MAY* fall below `min`. When that - # happens, it will open a new connection. It will - # also log a *WARNING* message. - # - # The solution is to either lower the `min` connections, - # or increase `lifetime`/`idle_timeout`. - # ==== - } -} diff --git a/scripts/asciidoc/links.txt b/scripts/asciidoc/links.txt index 8f9f505fc4..59a83e784e 100644 --- a/scripts/asciidoc/links.txt +++ b/scripts/asciidoc/links.txt @@ -200,6 +200,5 @@ Alc-ToClient-Dhcp-Options https://infoproducts.alcatel-lucent.com/html/0_add-h-f draft-sterman-aaa-sip-01 https://tools.ietf.org/html/draft-sterman-aaa-sip-01 draft-wahl-ldap-session https://tools.ietf.org/html/draft-wahl-ldap-session-03 PAM https://www.kernel.org/pub/linux/libs/pam/ -Couchbase https://www.couchbase.com/ GDBM https://www.gnu.org.ua/software/gdbm/ diff --git a/scripts/osx/install_deps.sh b/scripts/osx/install_deps.sh index ad25da1154..32143ba8a2 100755 --- a/scripts/osx/install_deps.sh +++ b/scripts/osx/install_deps.sh @@ -25,7 +25,6 @@ hiredis isc-dhcp json-c krb5 -libcouchbase libidn libmemcached libpcap diff --git a/src/modules/rlm_couchbase/.gitignore b/src/modules/rlm_couchbase/.gitignore deleted file mode 100644 index 01a5daa3cc..0000000000 --- a/src/modules/rlm_couchbase/.gitignore +++ /dev/null @@ -1 +0,0 @@ -all.mk diff --git a/src/modules/rlm_couchbase/README.md b/src/modules/rlm_couchbase/README.md deleted file mode 100644 index 57ff0f9ff5..0000000000 --- a/src/modules/rlm_couchbase/README.md +++ /dev/null @@ -1,9 +0,0 @@ -# rlm_couchbase -## Metadata -
-
category
datastore
-
- -## Summary -Allows attributes to be stored and retrieved from a couchbase server. Client definitions may also be bulk loaded from a -couchbase server as FreeRADIUS starts. diff --git a/src/modules/rlm_couchbase/all.mk.in b/src/modules/rlm_couchbase/all.mk.in deleted file mode 100644 index 0c787b0a78..0000000000 --- a/src/modules/rlm_couchbase/all.mk.in +++ /dev/null @@ -1,27 +0,0 @@ -# This needs to be cleared explicitly, as the libfreeradius-json.mk -# might not always be available, and the TARGETNAME from the previous -# target may stick around. -TARGETNAME := --include $(top_builddir)/src/lib/json/all.mk -TARGET := - -# Check the targetname defined by libfreeradius-json.mk -# to verify we have json-c and the libfreeradius-json library. -ifneq "$(TARGETNAME)" "" - TARGETNAME := @targetname@ - - # Check the targetname from the local configure script - ifneq "$(TARGETNAME)" "" - TARGET := $(TARGETNAME)$(L) - endif -endif - -SOURCES := $(TARGETNAME).c mod.c couchbase.c - -SRC_CFLAGS := @mod_cflags@ -TGT_LDLIBS := @mod_ldflags@ -TGT_PREREQS := libfreeradius-json.a - -# TODO: create man page -#MAN := rlm_couchbase.8 -LOG_ID_LIB = 7 diff --git a/src/modules/rlm_couchbase/config.h.in b/src/modules/rlm_couchbase/config.h.in deleted file mode 100644 index b429c2fc9f..0000000000 --- a/src/modules/rlm_couchbase/config.h.in +++ /dev/null @@ -1 +0,0 @@ -/* config.h.in. Generated from configure.ac by autoheader. */ diff --git a/src/modules/rlm_couchbase/configure b/src/modules/rlm_couchbase/configure deleted file mode 100755 index 7bf837b6b8..0000000000 --- a/src/modules/rlm_couchbase/configure +++ /dev/null @@ -1,5095 +0,0 @@ -#! /bin/sh -# From configure.ac Revision. -# Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.71. -# -# -# Copyright (C) 1992-1996, 1998-2017, 2020-2021 Free Software Foundation, -# Inc. -# -# -# This configure script is free software; the Free Software Foundation -# gives unlimited permission to copy, distribute and modify it. -## -------------------- ## -## M4sh Initialization. ## -## -------------------- ## - -# Be more Bourne compatible -DUALCASE=1; export DUALCASE # for MKS sh -as_nop=: -if test ${ZSH_VERSION+y} && (emulate sh) >/dev/null 2>&1 -then : - emulate sh - NULLCMD=: - # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else $as_nop - case `(set -o) 2>/dev/null` in #( - *posix*) : - set -o posix ;; #( - *) : - ;; -esac -fi - - - -# Reset variables that may have inherited troublesome values from -# the environment. - -# IFS needs to be set, to space, tab, and newline, in precisely that order. -# (If _AS_PATH_WALK were called with IFS unset, it would have the -# side effect of setting IFS to empty, thus disabling word splitting.) -# Quoting is to prevent editors from complaining about space-tab. -as_nl=' -' -export as_nl -IFS=" "" $as_nl" - -PS1='$ ' -PS2='> ' -PS4='+ ' - -# Ensure predictable behavior from utilities with locale-dependent output. -LC_ALL=C -export LC_ALL -LANGUAGE=C -export LANGUAGE - -# We cannot yet rely on "unset" to work, but we need these variables -# to be unset--not just set to an empty or harmless value--now, to -# avoid bugs in old shells (e.g. pre-3.0 UWIN ksh). This construct -# also avoids known problems related to "unset" and subshell syntax -# in other old shells (e.g. bash 2.01 and pdksh 5.2.14). -for as_var in BASH_ENV ENV MAIL MAILPATH CDPATH -do eval test \${$as_var+y} \ - && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : -done - -# Ensure that fds 0, 1, and 2 are open. -if (exec 3>&0) 2>/dev/null; then :; else exec 0&1) 2>/dev/null; then :; else exec 1>/dev/null; fi -if (exec 3>&2) ; then :; else exec 2>/dev/null; fi - -# The user is always right. -if ${PATH_SEPARATOR+false} :; then - PATH_SEPARATOR=: - (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { - (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || - PATH_SEPARATOR=';' - } -fi - - -# Find who we are. Look in the path if we contain no directory separator. -as_myself= -case $0 in #(( - *[\\/]* ) as_myself=$0 ;; - *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - test -r "$as_dir$0" && as_myself=$as_dir$0 && break - done -IFS=$as_save_IFS - - ;; -esac -# We did not find ourselves, most probably we were run as `sh COMMAND' -# in which case we are not to be found in the path. -if test "x$as_myself" = x; then - as_myself=$0 -fi -if test ! -f "$as_myself"; then - printf "%s\n" "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 - exit 1 -fi - - -# Use a proper internal environment variable to ensure we don't fall - # into an infinite loop, continuously re-executing ourselves. - if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then - _as_can_reexec=no; export _as_can_reexec; - # We cannot yet assume a decent shell, so we have to provide a -# neutralization value for shells without unset; and this also -# works around shells that cannot unset nonexistent variables. -# Preserve -v and -x to the replacement shell. -BASH_ENV=/dev/null -ENV=/dev/null -(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV -case $- in # (((( - *v*x* | *x*v* ) as_opts=-vx ;; - *v* ) as_opts=-v ;; - *x* ) as_opts=-x ;; - * ) as_opts= ;; -esac -exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} -# Admittedly, this is quite paranoid, since all the known shells bail -# out after a failed `exec'. -printf "%s\n" "$0: could not re-execute with $CONFIG_SHELL" >&2 -exit 255 - fi - # We don't want this to propagate to other subprocesses. - { _as_can_reexec=; unset _as_can_reexec;} -if test "x$CONFIG_SHELL" = x; then - as_bourne_compatible="as_nop=: -if test \${ZSH_VERSION+y} && (emulate sh) >/dev/null 2>&1 -then : - emulate sh - NULLCMD=: - # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which - # is contrary to our usage. Disable this feature. - alias -g '\${1+\"\$@\"}'='\"\$@\"' - setopt NO_GLOB_SUBST -else \$as_nop - case \`(set -o) 2>/dev/null\` in #( - *posix*) : - set -o posix ;; #( - *) : - ;; -esac -fi -" - as_required="as_fn_return () { (exit \$1); } -as_fn_success () { as_fn_return 0; } -as_fn_failure () { as_fn_return 1; } -as_fn_ret_success () { return 0; } -as_fn_ret_failure () { return 1; } - -exitcode=0 -as_fn_success || { exitcode=1; echo as_fn_success failed.; } -as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } -as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } -as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } -if ( set x; as_fn_ret_success y && test x = \"\$1\" ) -then : - -else \$as_nop - exitcode=1; echo positional parameters were not saved. -fi -test x\$exitcode = x0 || exit 1 -blah=\$(echo \$(echo blah)) -test x\"\$blah\" = xblah || exit 1 -test -x / || exit 1" - as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO - as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO - eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && - test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1" - if (eval "$as_required") 2>/dev/null -then : - as_have_required=yes -else $as_nop - as_have_required=no -fi - if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null -then : - -else $as_nop - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -as_found=false -for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - as_found=: - case $as_dir in #( - /*) - for as_base in sh bash ksh sh5; do - # Try only shells that exist, to save several forks. - as_shell=$as_dir$as_base - if { test -f "$as_shell" || test -f "$as_shell.exe"; } && - as_run=a "$as_shell" -c "$as_bourne_compatible""$as_required" 2>/dev/null -then : - CONFIG_SHELL=$as_shell as_have_required=yes - if as_run=a "$as_shell" -c "$as_bourne_compatible""$as_suggested" 2>/dev/null -then : - break 2 -fi -fi - done;; - esac - as_found=false -done -IFS=$as_save_IFS -if $as_found -then : - -else $as_nop - if { test -f "$SHELL" || test -f "$SHELL.exe"; } && - as_run=a "$SHELL" -c "$as_bourne_compatible""$as_required" 2>/dev/null -then : - CONFIG_SHELL=$SHELL as_have_required=yes -fi -fi - - - if test "x$CONFIG_SHELL" != x -then : - export CONFIG_SHELL - # We cannot yet assume a decent shell, so we have to provide a -# neutralization value for shells without unset; and this also -# works around shells that cannot unset nonexistent variables. -# Preserve -v and -x to the replacement shell. -BASH_ENV=/dev/null -ENV=/dev/null -(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV -case $- in # (((( - *v*x* | *x*v* ) as_opts=-vx ;; - *v* ) as_opts=-v ;; - *x* ) as_opts=-x ;; - * ) as_opts= ;; -esac -exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} -# Admittedly, this is quite paranoid, since all the known shells bail -# out after a failed `exec'. -printf "%s\n" "$0: could not re-execute with $CONFIG_SHELL" >&2 -exit 255 -fi - - if test x$as_have_required = xno -then : - printf "%s\n" "$0: This script requires a shell more modern than all" - printf "%s\n" "$0: the shells that I found on your system." - if test ${ZSH_VERSION+y} ; then - printf "%s\n" "$0: In particular, zsh $ZSH_VERSION has bugs and should" - printf "%s\n" "$0: be upgraded to zsh 4.3.4 or later." - else - printf "%s\n" "$0: Please tell bug-autoconf@gnu.org about your system, -$0: including any error possibly output before this -$0: message. Then install a modern shell, or manually run -$0: the script under such a shell if you do have one." - fi - exit 1 -fi -fi -fi -SHELL=${CONFIG_SHELL-/bin/sh} -export SHELL -# Unset more variables known to interfere with behavior of common tools. -CLICOLOR_FORCE= GREP_OPTIONS= -unset CLICOLOR_FORCE GREP_OPTIONS - -## --------------------- ## -## M4sh Shell Functions. ## -## --------------------- ## -# as_fn_unset VAR -# --------------- -# Portably unset VAR. -as_fn_unset () -{ - { eval $1=; unset $1;} -} -as_unset=as_fn_unset - - -# as_fn_set_status STATUS -# ----------------------- -# Set $? to STATUS, without forking. -as_fn_set_status () -{ - return $1 -} # as_fn_set_status - -# as_fn_exit STATUS -# ----------------- -# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. -as_fn_exit () -{ - set +e - as_fn_set_status $1 - exit $1 -} # as_fn_exit -# as_fn_nop -# --------- -# Do nothing but, unlike ":", preserve the value of $?. -as_fn_nop () -{ - return $? -} -as_nop=as_fn_nop - -# as_fn_mkdir_p -# ------------- -# Create "$as_dir" as a directory, including parents if necessary. -as_fn_mkdir_p () -{ - - case $as_dir in #( - -*) as_dir=./$as_dir;; - esac - test -d "$as_dir" || eval $as_mkdir_p || { - as_dirs= - while :; do - case $as_dir in #( - *\'*) as_qdir=`printf "%s\n" "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( - *) as_qdir=$as_dir;; - esac - as_dirs="'$as_qdir' $as_dirs" - as_dir=`$as_dirname -- "$as_dir" || -$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$as_dir" : 'X\(//\)[^/]' \| \ - X"$as_dir" : 'X\(//\)$' \| \ - X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || -printf "%s\n" X"$as_dir" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - test -d "$as_dir" && break - done - test -z "$as_dirs" || eval "mkdir $as_dirs" - } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" - - -} # as_fn_mkdir_p - -# as_fn_executable_p FILE -# ----------------------- -# Test if FILE is an executable regular file. -as_fn_executable_p () -{ - test -f "$1" && test -x "$1" -} # as_fn_executable_p -# as_fn_append VAR VALUE -# ---------------------- -# Append the text in VALUE to the end of the definition contained in VAR. Take -# advantage of any shell optimizations that allow amortized linear growth over -# repeated appends, instead of the typical quadratic growth present in naive -# implementations. -if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null -then : - eval 'as_fn_append () - { - eval $1+=\$2 - }' -else $as_nop - as_fn_append () - { - eval $1=\$$1\$2 - } -fi # as_fn_append - -# as_fn_arith ARG... -# ------------------ -# Perform arithmetic evaluation on the ARGs, and store the result in the -# global $as_val. Take advantage of shells that can avoid forks. The arguments -# must be portable across $(()) and expr. -if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null -then : - eval 'as_fn_arith () - { - as_val=$(( $* )) - }' -else $as_nop - as_fn_arith () - { - as_val=`expr "$@" || test $? -eq 1` - } -fi # as_fn_arith - -# as_fn_nop -# --------- -# Do nothing but, unlike ":", preserve the value of $?. -as_fn_nop () -{ - return $? -} -as_nop=as_fn_nop - -# as_fn_error STATUS ERROR [LINENO LOG_FD] -# ---------------------------------------- -# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are -# provided, also output the error to LOG_FD, referencing LINENO. Then exit the -# script with STATUS, using 1 if that was 0. -as_fn_error () -{ - as_status=$1; test $as_status -eq 0 && as_status=1 - if test "$4"; then - as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 - fi - printf "%s\n" "$as_me: error: $2" >&2 - as_fn_exit $as_status -} # as_fn_error - -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then - as_basename=basename -else - as_basename=false -fi - -if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then - as_dirname=dirname -else - as_dirname=false -fi - -as_me=`$as_basename -- "$0" || -$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -printf "%s\n" X/"$0" | - sed '/^.*\/\([^/][^/]*\)\/*$/{ - s//\1/ - q - } - /^X\/\(\/\/\)$/{ - s//\1/ - q - } - /^X\/\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - -# Avoid depending upon Character Ranges. -as_cr_letters='abcdefghijklmnopqrstuvwxyz' -as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -as_cr_Letters=$as_cr_letters$as_cr_LETTERS -as_cr_digits='0123456789' -as_cr_alnum=$as_cr_Letters$as_cr_digits - - - as_lineno_1=$LINENO as_lineno_1a=$LINENO - as_lineno_2=$LINENO as_lineno_2a=$LINENO - eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && - test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { - # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) - sed -n ' - p - /[$]LINENO/= - ' <$as_myself | - sed ' - s/[$]LINENO.*/&-/ - t lineno - b - :lineno - N - :loop - s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ - t loop - s/-\n.*// - ' >$as_me.lineno && - chmod +x "$as_me.lineno" || - { printf "%s\n" "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } - - # If we had to re-execute with $CONFIG_SHELL, we're ensured to have - # already done that, so ensure we don't try to do so again and fall - # in an infinite loop. This has already happened in practice. - _as_can_reexec=no; export _as_can_reexec - # Don't try to exec as it changes $[0], causing all sort of problems - # (the dirname of $[0] is not the place where we might find the - # original and so on. Autoconf is especially sensitive to this). - . "./$as_me.lineno" - # Exit status is that of the last command. - exit -} - - -# Determine whether it's possible to make 'echo' print without a newline. -# These variables are no longer used directly by Autoconf, but are AC_SUBSTed -# for compatibility with existing Makefiles. -ECHO_C= ECHO_N= ECHO_T= -case `echo -n x` in #((((( --n*) - case `echo 'xy\c'` in - *c*) ECHO_T=' ';; # ECHO_T is single tab character. - xy) ECHO_C='\c';; - *) echo `echo ksh88 bug on AIX 6.1` > /dev/null - ECHO_T=' ';; - esac;; -*) - ECHO_N='-n';; -esac - -# For backward compatibility with old third-party macros, we provide -# the shell variables $as_echo and $as_echo_n. New code should use -# AS_ECHO(["message"]) and AS_ECHO_N(["message"]), respectively. -as_echo='printf %s\n' -as_echo_n='printf %s' - - -rm -f conf$$ conf$$.exe conf$$.file -if test -d conf$$.dir; then - rm -f conf$$.dir/conf$$.file -else - rm -f conf$$.dir - mkdir conf$$.dir 2>/dev/null -fi -if (echo >conf$$.file) 2>/dev/null; then - if ln -s conf$$.file conf$$ 2>/dev/null; then - as_ln_s='ln -s' - # ... but there are two gotchas: - # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. - # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. - # In both cases, we have to default to `cp -pR'. - ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || - as_ln_s='cp -pR' - elif ln conf$$.file conf$$ 2>/dev/null; then - as_ln_s=ln - else - as_ln_s='cp -pR' - fi -else - as_ln_s='cp -pR' -fi -rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file -rmdir conf$$.dir 2>/dev/null - -if mkdir -p . 2>/dev/null; then - as_mkdir_p='mkdir -p "$as_dir"' -else - test -d ./-p && rmdir ./-p - as_mkdir_p=false -fi - -as_test_x='test -x' -as_executable_p=as_fn_executable_p - -# Sed expression to map a string onto a valid CPP name. -as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" - -# Sed expression to map a string onto a valid variable name. -as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" - - -test -n "$DJDIR" || exec 7<&0 &1 - -# Name of the host. -# hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, -# so uname gets run too. -ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` - -# -# Initializations. -# -ac_default_prefix=/usr/local -ac_clean_files= -ac_config_libobj_dir=. -LIBOBJS= -cross_compiling=no -subdirs= -MFLAGS= -MAKEFLAGS= - -# Identity of this package. -PACKAGE_NAME='' -PACKAGE_TARNAME='' -PACKAGE_VERSION='' -PACKAGE_STRING='' -PACKAGE_BUGREPORT='' -PACKAGE_URL='' - -ac_unique_file="rlm_couchbase.c" -ac_subst_vars='LTLIBOBJS -LIBOBJS -mod_ldflags -mod_cflags -targetname -CPP -OBJEXT -EXEEXT -ac_ct_CC -CPPFLAGS -LDFLAGS -CFLAGS -CC -target_alias -host_alias -build_alias -LIBS -ECHO_T -ECHO_N -ECHO_C -DEFS -mandir -localedir -libdir -psdir -pdfdir -dvidir -htmldir -infodir -docdir -oldincludedir -includedir -runstatedir -localstatedir -sharedstatedir -sysconfdir -datadir -datarootdir -libexecdir -sbindir -bindir -program_transform_name -prefix -exec_prefix -PACKAGE_URL -PACKAGE_BUGREPORT -PACKAGE_STRING -PACKAGE_VERSION -PACKAGE_TARNAME -PACKAGE_NAME -PATH_SEPARATOR -SHELL' -ac_subst_files='' -ac_user_opts=' -enable_option_checking -with_rlm_couchbase -with_libcouchbase_include_dir -with_libcouchbase_lib_dir -with_libcouchbase_dir -' - ac_precious_vars='build_alias -host_alias -target_alias -CC -CFLAGS -LDFLAGS -LIBS -CPPFLAGS -CPP' - - -# Initialize some variables set by options. -ac_init_help= -ac_init_version=false -ac_unrecognized_opts= -ac_unrecognized_sep= -# The variables have the same names as the options, with -# dashes changed to underlines. -cache_file=/dev/null -exec_prefix=NONE -no_create= -no_recursion= -prefix=NONE -program_prefix=NONE -program_suffix=NONE -program_transform_name=s,x,x, -silent= -site= -srcdir= -verbose= -x_includes=NONE -x_libraries=NONE - -# Installation directory options. -# These are left unexpanded so users can "make install exec_prefix=/foo" -# and all the variables that are supposed to be based on exec_prefix -# by default will actually change. -# Use braces instead of parens because sh, perl, etc. also accept them. -# (The list follows the same order as the GNU Coding Standards.) -bindir='${exec_prefix}/bin' -sbindir='${exec_prefix}/sbin' -libexecdir='${exec_prefix}/libexec' -datarootdir='${prefix}/share' -datadir='${datarootdir}' -sysconfdir='${prefix}/etc' -sharedstatedir='${prefix}/com' -localstatedir='${prefix}/var' -runstatedir='${localstatedir}/run' -includedir='${prefix}/include' -oldincludedir='/usr/include' -docdir='${datarootdir}/doc/${PACKAGE}' -infodir='${datarootdir}/info' -htmldir='${docdir}' -dvidir='${docdir}' -pdfdir='${docdir}' -psdir='${docdir}' -libdir='${exec_prefix}/lib' -localedir='${datarootdir}/locale' -mandir='${datarootdir}/man' - -ac_prev= -ac_dashdash= -for ac_option -do - # If the previous option needs an argument, assign it. - if test -n "$ac_prev"; then - eval $ac_prev=\$ac_option - ac_prev= - continue - fi - - case $ac_option in - *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; - *=) ac_optarg= ;; - *) ac_optarg=yes ;; - esac - - case $ac_dashdash$ac_option in - --) - ac_dashdash=yes ;; - - -bindir | --bindir | --bindi | --bind | --bin | --bi) - ac_prev=bindir ;; - -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) - bindir=$ac_optarg ;; - - -build | --build | --buil | --bui | --bu) - ac_prev=build_alias ;; - -build=* | --build=* | --buil=* | --bui=* | --bu=*) - build_alias=$ac_optarg ;; - - -cache-file | --cache-file | --cache-fil | --cache-fi \ - | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) - ac_prev=cache_file ;; - -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ - | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) - cache_file=$ac_optarg ;; - - --config-cache | -C) - cache_file=config.cache ;; - - -datadir | --datadir | --datadi | --datad) - ac_prev=datadir ;; - -datadir=* | --datadir=* | --datadi=* | --datad=*) - datadir=$ac_optarg ;; - - -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ - | --dataroo | --dataro | --datar) - ac_prev=datarootdir ;; - -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ - | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) - datarootdir=$ac_optarg ;; - - -disable-* | --disable-*) - ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error $? "invalid feature name: \`$ac_useropt'" - ac_useropt_orig=$ac_useropt - ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"enable_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval enable_$ac_useropt=no ;; - - -docdir | --docdir | --docdi | --doc | --do) - ac_prev=docdir ;; - -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) - docdir=$ac_optarg ;; - - -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) - ac_prev=dvidir ;; - -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) - dvidir=$ac_optarg ;; - - -enable-* | --enable-*) - ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error $? "invalid feature name: \`$ac_useropt'" - ac_useropt_orig=$ac_useropt - ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"enable_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval enable_$ac_useropt=\$ac_optarg ;; - - -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ - | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ - | --exec | --exe | --ex) - ac_prev=exec_prefix ;; - -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ - | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ - | --exec=* | --exe=* | --ex=*) - exec_prefix=$ac_optarg ;; - - -gas | --gas | --ga | --g) - # Obsolete; use --with-gas. - with_gas=yes ;; - - -help | --help | --hel | --he | -h) - ac_init_help=long ;; - -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) - ac_init_help=recursive ;; - -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) - ac_init_help=short ;; - - -host | --host | --hos | --ho) - ac_prev=host_alias ;; - -host=* | --host=* | --hos=* | --ho=*) - host_alias=$ac_optarg ;; - - -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) - ac_prev=htmldir ;; - -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ - | --ht=*) - htmldir=$ac_optarg ;; - - -includedir | --includedir | --includedi | --included | --include \ - | --includ | --inclu | --incl | --inc) - ac_prev=includedir ;; - -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ - | --includ=* | --inclu=* | --incl=* | --inc=*) - includedir=$ac_optarg ;; - - -infodir | --infodir | --infodi | --infod | --info | --inf) - ac_prev=infodir ;; - -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) - infodir=$ac_optarg ;; - - -libdir | --libdir | --libdi | --libd) - ac_prev=libdir ;; - -libdir=* | --libdir=* | --libdi=* | --libd=*) - libdir=$ac_optarg ;; - - -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ - | --libexe | --libex | --libe) - ac_prev=libexecdir ;; - -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ - | --libexe=* | --libex=* | --libe=*) - libexecdir=$ac_optarg ;; - - -localedir | --localedir | --localedi | --localed | --locale) - ac_prev=localedir ;; - -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) - localedir=$ac_optarg ;; - - -localstatedir | --localstatedir | --localstatedi | --localstated \ - | --localstate | --localstat | --localsta | --localst | --locals) - ac_prev=localstatedir ;; - -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ - | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) - localstatedir=$ac_optarg ;; - - -mandir | --mandir | --mandi | --mand | --man | --ma | --m) - ac_prev=mandir ;; - -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) - mandir=$ac_optarg ;; - - -nfp | --nfp | --nf) - # Obsolete; use --without-fp. - with_fp=no ;; - - -no-create | --no-create | --no-creat | --no-crea | --no-cre \ - | --no-cr | --no-c | -n) - no_create=yes ;; - - -no-recursion | --no-recursion | --no-recursio | --no-recursi \ - | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) - no_recursion=yes ;; - - -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ - | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ - | --oldin | --oldi | --old | --ol | --o) - ac_prev=oldincludedir ;; - -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ - | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ - | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) - oldincludedir=$ac_optarg ;; - - -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) - ac_prev=prefix ;; - -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) - prefix=$ac_optarg ;; - - -program-prefix | --program-prefix | --program-prefi | --program-pref \ - | --program-pre | --program-pr | --program-p) - ac_prev=program_prefix ;; - -program-prefix=* | --program-prefix=* | --program-prefi=* \ - | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) - program_prefix=$ac_optarg ;; - - -program-suffix | --program-suffix | --program-suffi | --program-suff \ - | --program-suf | --program-su | --program-s) - ac_prev=program_suffix ;; - -program-suffix=* | --program-suffix=* | --program-suffi=* \ - | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) - program_suffix=$ac_optarg ;; - - -program-transform-name | --program-transform-name \ - | --program-transform-nam | --program-transform-na \ - | --program-transform-n | --program-transform- \ - | --program-transform | --program-transfor \ - | --program-transfo | --program-transf \ - | --program-trans | --program-tran \ - | --progr-tra | --program-tr | --program-t) - ac_prev=program_transform_name ;; - -program-transform-name=* | --program-transform-name=* \ - | --program-transform-nam=* | --program-transform-na=* \ - | --program-transform-n=* | --program-transform-=* \ - | --program-transform=* | --program-transfor=* \ - | --program-transfo=* | --program-transf=* \ - | --program-trans=* | --program-tran=* \ - | --progr-tra=* | --program-tr=* | --program-t=*) - program_transform_name=$ac_optarg ;; - - -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) - ac_prev=pdfdir ;; - -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) - pdfdir=$ac_optarg ;; - - -psdir | --psdir | --psdi | --psd | --ps) - ac_prev=psdir ;; - -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) - psdir=$ac_optarg ;; - - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil) - silent=yes ;; - - -runstatedir | --runstatedir | --runstatedi | --runstated \ - | --runstate | --runstat | --runsta | --runst | --runs \ - | --run | --ru | --r) - ac_prev=runstatedir ;; - -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \ - | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \ - | --run=* | --ru=* | --r=*) - runstatedir=$ac_optarg ;; - - -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) - ac_prev=sbindir ;; - -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ - | --sbi=* | --sb=*) - sbindir=$ac_optarg ;; - - -sharedstatedir | --sharedstatedir | --sharedstatedi \ - | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ - | --sharedst | --shareds | --shared | --share | --shar \ - | --sha | --sh) - ac_prev=sharedstatedir ;; - -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ - | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ - | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ - | --sha=* | --sh=*) - sharedstatedir=$ac_optarg ;; - - -site | --site | --sit) - ac_prev=site ;; - -site=* | --site=* | --sit=*) - site=$ac_optarg ;; - - -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) - ac_prev=srcdir ;; - -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) - srcdir=$ac_optarg ;; - - -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ - | --syscon | --sysco | --sysc | --sys | --sy) - ac_prev=sysconfdir ;; - -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ - | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) - sysconfdir=$ac_optarg ;; - - -target | --target | --targe | --targ | --tar | --ta | --t) - ac_prev=target_alias ;; - -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) - target_alias=$ac_optarg ;; - - -v | -verbose | --verbose | --verbos | --verbo | --verb) - verbose=yes ;; - - -version | --version | --versio | --versi | --vers | -V) - ac_init_version=: ;; - - -with-* | --with-*) - ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error $? "invalid package name: \`$ac_useropt'" - ac_useropt_orig=$ac_useropt - ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"with_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval with_$ac_useropt=\$ac_optarg ;; - - -without-* | --without-*) - ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error $? "invalid package name: \`$ac_useropt'" - ac_useropt_orig=$ac_useropt - ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"with_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval with_$ac_useropt=no ;; - - --x) - # Obsolete; use --with-x. - with_x=yes ;; - - -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ - | --x-incl | --x-inc | --x-in | --x-i) - ac_prev=x_includes ;; - -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ - | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) - x_includes=$ac_optarg ;; - - -x-libraries | --x-libraries | --x-librarie | --x-librari \ - | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) - ac_prev=x_libraries ;; - -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ - | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) - x_libraries=$ac_optarg ;; - - -*) as_fn_error $? "unrecognized option: \`$ac_option' -Try \`$0 --help' for more information" - ;; - - *=*) - ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` - # Reject names that are not valid shell variable names. - case $ac_envvar in #( - '' | [0-9]* | *[!_$as_cr_alnum]* ) - as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; - esac - eval $ac_envvar=\$ac_optarg - export $ac_envvar ;; - - *) - # FIXME: should be removed in autoconf 3.0. - printf "%s\n" "$as_me: WARNING: you should use --build, --host, --target" >&2 - expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && - printf "%s\n" "$as_me: WARNING: invalid host type: $ac_option" >&2 - : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" - ;; - - esac -done - -if test -n "$ac_prev"; then - ac_option=--`echo $ac_prev | sed 's/_/-/g'` - as_fn_error $? "missing argument to $ac_option" -fi - -if test -n "$ac_unrecognized_opts"; then - case $enable_option_checking in - no) ;; - fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; - *) printf "%s\n" "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; - esac -fi - -# Check all directory arguments for consistency. -for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ - datadir sysconfdir sharedstatedir localstatedir includedir \ - oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ - libdir localedir mandir runstatedir -do - eval ac_val=\$$ac_var - # Remove trailing slashes. - case $ac_val in - */ ) - ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` - eval $ac_var=\$ac_val;; - esac - # Be sure to have absolute directory names. - case $ac_val in - [\\/$]* | ?:[\\/]* ) continue;; - NONE | '' ) case $ac_var in *prefix ) continue;; esac;; - esac - as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" -done - -# There might be people who depend on the old broken behavior: `$host' -# used to hold the argument of --host etc. -# FIXME: To remove some day. -build=$build_alias -host=$host_alias -target=$target_alias - -# FIXME: To remove some day. -if test "x$host_alias" != x; then - if test "x$build_alias" = x; then - cross_compiling=maybe - elif test "x$build_alias" != "x$host_alias"; then - cross_compiling=yes - fi -fi - -ac_tool_prefix= -test -n "$host_alias" && ac_tool_prefix=$host_alias- - -test "$silent" = yes && exec 6>/dev/null - - -ac_pwd=`pwd` && test -n "$ac_pwd" && -ac_ls_di=`ls -di .` && -ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || - as_fn_error $? "working directory cannot be determined" -test "X$ac_ls_di" = "X$ac_pwd_ls_di" || - as_fn_error $? "pwd does not report name of working directory" - - -# Find the source files, if location was not specified. -if test -z "$srcdir"; then - ac_srcdir_defaulted=yes - # Try the directory containing this script, then the parent directory. - ac_confdir=`$as_dirname -- "$as_myself" || -$as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$as_myself" : 'X\(//\)[^/]' \| \ - X"$as_myself" : 'X\(//\)$' \| \ - X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || -printf "%s\n" X"$as_myself" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - srcdir=$ac_confdir - if test ! -r "$srcdir/$ac_unique_file"; then - srcdir=.. - fi -else - ac_srcdir_defaulted=no -fi -if test ! -r "$srcdir/$ac_unique_file"; then - test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." - as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" -fi -ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" -ac_abs_confdir=`( - cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" - pwd)` -# When building in place, set srcdir=. -if test "$ac_abs_confdir" = "$ac_pwd"; then - srcdir=. -fi -# Remove unnecessary trailing slashes from srcdir. -# Double slashes in file names in object file debugging info -# mess up M-x gdb in Emacs. -case $srcdir in -*/) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; -esac -for ac_var in $ac_precious_vars; do - eval ac_env_${ac_var}_set=\${${ac_var}+set} - eval ac_env_${ac_var}_value=\$${ac_var} - eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} - eval ac_cv_env_${ac_var}_value=\$${ac_var} -done - -# -# Report the --help message. -# -if test "$ac_init_help" = "long"; then - # Omit some internal or obsolete options to make the list less imposing. - # This message is too long to be a string in the A/UX 3.1 sh. - cat <<_ACEOF -\`configure' configures this package to adapt to many kinds of systems. - -Usage: $0 [OPTION]... [VAR=VALUE]... - -To assign environment variables (e.g., CC, CFLAGS...), specify them as -VAR=VALUE. See below for descriptions of some of the useful variables. - -Defaults for the options are specified in brackets. - -Configuration: - -h, --help display this help and exit - --help=short display options specific to this package - --help=recursive display the short help of all the included packages - -V, --version display version information and exit - -q, --quiet, --silent do not print \`checking ...' messages - --cache-file=FILE cache test results in FILE [disabled] - -C, --config-cache alias for \`--cache-file=config.cache' - -n, --no-create do not create output files - --srcdir=DIR find the sources in DIR [configure dir or \`..'] - -Installation directories: - --prefix=PREFIX install architecture-independent files in PREFIX - [$ac_default_prefix] - --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX - [PREFIX] - -By default, \`make install' will install all the files in -\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify -an installation prefix other than \`$ac_default_prefix' using \`--prefix', -for instance \`--prefix=\$HOME'. - -For better control, use the options below. - -Fine tuning of the installation directories: - --bindir=DIR user executables [EPREFIX/bin] - --sbindir=DIR system admin executables [EPREFIX/sbin] - --libexecdir=DIR program executables [EPREFIX/libexec] - --sysconfdir=DIR read-only single-machine data [PREFIX/etc] - --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] - --localstatedir=DIR modifiable single-machine data [PREFIX/var] - --runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run] - --libdir=DIR object code libraries [EPREFIX/lib] - --includedir=DIR C header files [PREFIX/include] - --oldincludedir=DIR C header files for non-gcc [/usr/include] - --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] - --datadir=DIR read-only architecture-independent data [DATAROOTDIR] - --infodir=DIR info documentation [DATAROOTDIR/info] - --localedir=DIR locale-dependent data [DATAROOTDIR/locale] - --mandir=DIR man documentation [DATAROOTDIR/man] - --docdir=DIR documentation root [DATAROOTDIR/doc/PACKAGE] - --htmldir=DIR html documentation [DOCDIR] - --dvidir=DIR dvi documentation [DOCDIR] - --pdfdir=DIR pdf documentation [DOCDIR] - --psdir=DIR ps documentation [DOCDIR] -_ACEOF - - cat <<\_ACEOF -_ACEOF -fi - -if test -n "$ac_init_help"; then - - cat <<\_ACEOF - -Optional Packages: - --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] - --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) - --without-rlm_couchbase build without couchbase database support - --with-libcouchbase-include-dir=DIR - Directory where the libcouchbase includes may be - found - --with-libcouchbase-lib-dir=DIR - Directory where the libcouchbase libraries may be - found - --with-libcouchbase-dir=DIR - Base directory where libcouchbase is installed - -Some influential environment variables: - CC C compiler command - CFLAGS C compiler flags - LDFLAGS linker flags, e.g. -L if you have libraries in a - nonstandard directory - LIBS libraries to pass to the linker, e.g. -l - CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if - you have headers in a nonstandard directory - CPP C preprocessor - -Use these variables to override the choices made by `configure' or to help -it to find libraries and programs with nonstandard names/locations. - -Report bugs to the package provider. -_ACEOF -ac_status=$? -fi - -if test "$ac_init_help" = "recursive"; then - # If there are subdirs, report their specific --help. - for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue - test -d "$ac_dir" || - { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || - continue - ac_builddir=. - -case "$ac_dir" in -.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; -*) - ac_dir_suffix=/`printf "%s\n" "$ac_dir" | sed 's|^\.[\\/]||'` - # A ".." for each directory in $ac_dir_suffix. - ac_top_builddir_sub=`printf "%s\n" "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` - case $ac_top_builddir_sub in - "") ac_top_builddir_sub=. ac_top_build_prefix= ;; - *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; - esac ;; -esac -ac_abs_top_builddir=$ac_pwd -ac_abs_builddir=$ac_pwd$ac_dir_suffix -# for backward compatibility: -ac_top_builddir=$ac_top_build_prefix - -case $srcdir in - .) # We are building in place. - ac_srcdir=. - ac_top_srcdir=$ac_top_builddir_sub - ac_abs_top_srcdir=$ac_pwd ;; - [\\/]* | ?:[\\/]* ) # Absolute name. - ac_srcdir=$srcdir$ac_dir_suffix; - ac_top_srcdir=$srcdir - ac_abs_top_srcdir=$srcdir ;; - *) # Relative name. - ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix - ac_top_srcdir=$ac_top_build_prefix$srcdir - ac_abs_top_srcdir=$ac_pwd/$srcdir ;; -esac -ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix - - cd "$ac_dir" || { ac_status=$?; continue; } - # Check for configure.gnu first; this name is used for a wrapper for - # Metaconfig's "Configure" on case-insensitive file systems. - if test -f "$ac_srcdir/configure.gnu"; then - echo && - $SHELL "$ac_srcdir/configure.gnu" --help=recursive - elif test -f "$ac_srcdir/configure"; then - echo && - $SHELL "$ac_srcdir/configure" --help=recursive - else - printf "%s\n" "$as_me: WARNING: no configuration information is in $ac_dir" >&2 - fi || ac_status=$? - cd "$ac_pwd" || { ac_status=$?; break; } - done -fi - -test -n "$ac_init_help" && exit $ac_status -if $ac_init_version; then - cat <<\_ACEOF -configure -generated by GNU Autoconf 2.71 - -Copyright (C) 2021 Free Software Foundation, Inc. -This configure script is free software; the Free Software Foundation -gives unlimited permission to copy, distribute and modify it. -_ACEOF - exit -fi - -## ------------------------ ## -## Autoconf initialization. ## -## ------------------------ ## - -echo -echo Running tests for rlm_couchbase -echo - - -# ac_fn_c_try_compile LINENO -# -------------------------- -# Try to compile conftest.$ac_ext, and return whether this succeeded. -ac_fn_c_try_compile () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - rm -f conftest.$ac_objext conftest.beam - if { { ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_compile") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - grep -v '^ *+' conftest.err >conftest.er1 - cat conftest.er1 >&5 - mv -f conftest.er1 conftest.err - fi - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext -then : - ac_retval=0 -else $as_nop - printf "%s\n" "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=1 -fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno - as_fn_set_status $ac_retval - -} # ac_fn_c_try_compile - -# ac_fn_c_try_cpp LINENO -# ---------------------- -# Try to preprocess conftest.$ac_ext, and return whether this succeeded. -ac_fn_c_try_cpp () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if { { ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - grep -v '^ *+' conftest.err >conftest.er1 - cat conftest.er1 >&5 - mv -f conftest.er1 conftest.err - fi - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } > conftest.i && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - } -then : - ac_retval=0 -else $as_nop - printf "%s\n" "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=1 -fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno - as_fn_set_status $ac_retval - -} # ac_fn_c_try_cpp - -# ac_fn_c_try_link LINENO -# ----------------------- -# Try to link conftest.$ac_ext, and return whether this succeeded. -ac_fn_c_try_link () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - rm -f conftest.$ac_objext conftest.beam conftest$ac_exeext - if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - grep -v '^ *+' conftest.err >conftest.er1 - cat conftest.er1 >&5 - mv -f conftest.er1 conftest.err - fi - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && { - test "$cross_compiling" = yes || - test -x conftest$ac_exeext - } -then : - ac_retval=0 -else $as_nop - printf "%s\n" "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=1 -fi - # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information - # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would - # interfere with the next link command; also delete a directory that is - # left behind by Apple's compiler. We do this before executing the actions. - rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno - as_fn_set_status $ac_retval - -} # ac_fn_c_try_link -ac_configure_args_raw= -for ac_arg -do - case $ac_arg in - *\'*) - ac_arg=`printf "%s\n" "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - as_fn_append ac_configure_args_raw " '$ac_arg'" -done - -case $ac_configure_args_raw in - *$as_nl*) - ac_safe_unquote= ;; - *) - ac_unsafe_z='|&;<>()$`\\"*?[ '' ' # This string ends in space, tab. - ac_unsafe_a="$ac_unsafe_z#~" - ac_safe_unquote="s/ '\\([^$ac_unsafe_a][^$ac_unsafe_z]*\\)'/ \\1/g" - ac_configure_args_raw=` printf "%s\n" "$ac_configure_args_raw" | sed "$ac_safe_unquote"`;; -esac - -cat >config.log <<_ACEOF -This file contains any messages produced by compilers while -running configure, to aid debugging if configure makes a mistake. - -It was created by $as_me, which was -generated by GNU Autoconf 2.71. Invocation command line was - - $ $0$ac_configure_args_raw - -_ACEOF -exec 5>>config.log -{ -cat <<_ASUNAME -## --------- ## -## Platform. ## -## --------- ## - -hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` -uname -m = `(uname -m) 2>/dev/null || echo unknown` -uname -r = `(uname -r) 2>/dev/null || echo unknown` -uname -s = `(uname -s) 2>/dev/null || echo unknown` -uname -v = `(uname -v) 2>/dev/null || echo unknown` - -/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` -/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` - -/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` -/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` -/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` -/usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` -/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` -/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` -/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` - -_ASUNAME - -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - printf "%s\n" "PATH: $as_dir" - done -IFS=$as_save_IFS - -} >&5 - -cat >&5 <<_ACEOF - - -## ----------- ## -## Core tests. ## -## ----------- ## - -_ACEOF - - -# Keep a trace of the command line. -# Strip out --no-create and --no-recursion so they do not pile up. -# Strip out --silent because we don't want to record it for future runs. -# Also quote any args containing shell meta-characters. -# Make two passes to allow for proper duplicate-argument suppression. -ac_configure_args= -ac_configure_args0= -ac_configure_args1= -ac_must_keep_next=false -for ac_pass in 1 2 -do - for ac_arg - do - case $ac_arg in - -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil) - continue ;; - *\'*) - ac_arg=`printf "%s\n" "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - case $ac_pass in - 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; - 2) - as_fn_append ac_configure_args1 " '$ac_arg'" - if test $ac_must_keep_next = true; then - ac_must_keep_next=false # Got value, back to normal. - else - case $ac_arg in - *=* | --config-cache | -C | -disable-* | --disable-* \ - | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ - | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ - | -with-* | --with-* | -without-* | --without-* | --x) - case "$ac_configure_args0 " in - "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; - esac - ;; - -* ) ac_must_keep_next=true ;; - esac - fi - as_fn_append ac_configure_args " '$ac_arg'" - ;; - esac - done -done -{ ac_configure_args0=; unset ac_configure_args0;} -{ ac_configure_args1=; unset ac_configure_args1;} - -# When interrupted or exit'd, cleanup temporary files, and complete -# config.log. We remove comments because anyway the quotes in there -# would cause problems or look ugly. -# WARNING: Use '\'' to represent an apostrophe within the trap. -# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. -trap 'exit_status=$? - # Sanitize IFS. - IFS=" "" $as_nl" - # Save into config.log some information that might help in debugging. - { - echo - - printf "%s\n" "## ---------------- ## -## Cache variables. ## -## ---------------- ##" - echo - # The following way of writing the cache mishandles newlines in values, -( - for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do - eval ac_val=\$$ac_var - case $ac_val in #( - *${as_nl}*) - case $ac_var in #( - *_cv_*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 -printf "%s\n" "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; - esac - case $ac_var in #( - _ | IFS | as_nl) ;; #( - BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( - *) { eval $ac_var=; unset $ac_var;} ;; - esac ;; - esac - done - (set) 2>&1 | - case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( - *${as_nl}ac_space=\ *) - sed -n \ - "s/'\''/'\''\\\\'\'''\''/g; - s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" - ;; #( - *) - sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" - ;; - esac | - sort -) - echo - - printf "%s\n" "## ----------------- ## -## Output variables. ## -## ----------------- ##" - echo - for ac_var in $ac_subst_vars - do - eval ac_val=\$$ac_var - case $ac_val in - *\'\''*) ac_val=`printf "%s\n" "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; - esac - printf "%s\n" "$ac_var='\''$ac_val'\''" - done | sort - echo - - if test -n "$ac_subst_files"; then - printf "%s\n" "## ------------------- ## -## File substitutions. ## -## ------------------- ##" - echo - for ac_var in $ac_subst_files - do - eval ac_val=\$$ac_var - case $ac_val in - *\'\''*) ac_val=`printf "%s\n" "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; - esac - printf "%s\n" "$ac_var='\''$ac_val'\''" - done | sort - echo - fi - - if test -s confdefs.h; then - printf "%s\n" "## ----------- ## -## confdefs.h. ## -## ----------- ##" - echo - cat confdefs.h - echo - fi - test "$ac_signal" != 0 && - printf "%s\n" "$as_me: caught signal $ac_signal" - printf "%s\n" "$as_me: exit $exit_status" - } >&5 - rm -f core *.core core.conftest.* && - rm -f -r conftest* confdefs* conf$$* $ac_clean_files && - exit $exit_status -' 0 -for ac_signal in 1 2 13 15; do - trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal -done -ac_signal=0 - -# confdefs.h avoids OS command line length limits that DEFS can exceed. -rm -f -r conftest* confdefs.h - -printf "%s\n" "/* confdefs.h */" > confdefs.h - -# Predefined preprocessor variables. - -printf "%s\n" "#define PACKAGE_NAME \"$PACKAGE_NAME\"" >>confdefs.h - -printf "%s\n" "#define PACKAGE_TARNAME \"$PACKAGE_TARNAME\"" >>confdefs.h - -printf "%s\n" "#define PACKAGE_VERSION \"$PACKAGE_VERSION\"" >>confdefs.h - -printf "%s\n" "#define PACKAGE_STRING \"$PACKAGE_STRING\"" >>confdefs.h - -printf "%s\n" "#define PACKAGE_BUGREPORT \"$PACKAGE_BUGREPORT\"" >>confdefs.h - -printf "%s\n" "#define PACKAGE_URL \"$PACKAGE_URL\"" >>confdefs.h - - -# Let the site file select an alternate cache file if it wants to. -# Prefer an explicitly selected file to automatically selected ones. -if test -n "$CONFIG_SITE"; then - ac_site_files="$CONFIG_SITE" -elif test "x$prefix" != xNONE; then - ac_site_files="$prefix/share/config.site $prefix/etc/config.site" -else - ac_site_files="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site" -fi - -for ac_site_file in $ac_site_files -do - case $ac_site_file in #( - */*) : - ;; #( - *) : - ac_site_file=./$ac_site_file ;; -esac - if test -f "$ac_site_file" && test -r "$ac_site_file"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 -printf "%s\n" "$as_me: loading site script $ac_site_file" >&6;} - sed 's/^/| /' "$ac_site_file" >&5 - . "$ac_site_file" \ - || { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "failed to load site script $ac_site_file -See \`config.log' for more details" "$LINENO" 5; } - fi -done - -if test -r "$cache_file"; then - # Some versions of bash will fail to source /dev/null (special files - # actually), so we avoid doing that. DJGPP emulates it as a regular file. - if test /dev/null != "$cache_file" && test -f "$cache_file"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 -printf "%s\n" "$as_me: loading cache $cache_file" >&6;} - case $cache_file in - [\\/]* | ?:[\\/]* ) . "$cache_file";; - *) . "./$cache_file";; - esac - fi -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 -printf "%s\n" "$as_me: creating cache $cache_file" >&6;} - >$cache_file -fi - -# Test code for whether the C compiler supports C89 (global declarations) -ac_c_conftest_c89_globals=' -/* Does the compiler advertise C89 conformance? - Do not test the value of __STDC__, because some compilers set it to 0 - while being otherwise adequately conformant. */ -#if !defined __STDC__ -# error "Compiler does not advertise C89 conformance" -#endif - -#include -#include -struct stat; -/* Most of the following tests are stolen from RCS 5.7 src/conf.sh. */ -struct buf { int x; }; -struct buf * (*rcsopen) (struct buf *, struct stat *, int); -static char *e (p, i) - char **p; - int i; -{ - return p[i]; -} -static char *f (char * (*g) (char **, int), char **p, ...) -{ - char *s; - va_list v; - va_start (v,p); - s = g (p, va_arg (v,int)); - va_end (v); - return s; -} - -/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has - function prototypes and stuff, but not \xHH hex character constants. - These do not provoke an error unfortunately, instead are silently treated - as an "x". The following induces an error, until -std is added to get - proper ANSI mode. Curiously \x00 != x always comes out true, for an - array size at least. It is necessary to write \x00 == 0 to get something - that is true only with -std. */ -int osf4_cc_array ['\''\x00'\'' == 0 ? 1 : -1]; - -/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters - inside strings and character constants. */ -#define FOO(x) '\''x'\'' -int xlc6_cc_array[FOO(a) == '\''x'\'' ? 1 : -1]; - -int test (int i, double x); -struct s1 {int (*f) (int a);}; -struct s2 {int (*f) (double a);}; -int pairnames (int, char **, int *(*)(struct buf *, struct stat *, int), - int, int);' - -# Test code for whether the C compiler supports C89 (body of main). -ac_c_conftest_c89_main=' -ok |= (argc == 0 || f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]); -' - -# Test code for whether the C compiler supports C99 (global declarations) -ac_c_conftest_c99_globals=' -// Does the compiler advertise C99 conformance? -#if !defined __STDC_VERSION__ || __STDC_VERSION__ < 199901L -# error "Compiler does not advertise C99 conformance" -#endif - -#include -extern int puts (const char *); -extern int printf (const char *, ...); -extern int dprintf (int, const char *, ...); -extern void *malloc (size_t); - -// Check varargs macros. These examples are taken from C99 6.10.3.5. -// dprintf is used instead of fprintf to avoid needing to declare -// FILE and stderr. -#define debug(...) dprintf (2, __VA_ARGS__) -#define showlist(...) puts (#__VA_ARGS__) -#define report(test,...) ((test) ? puts (#test) : printf (__VA_ARGS__)) -static void -test_varargs_macros (void) -{ - int x = 1234; - int y = 5678; - debug ("Flag"); - debug ("X = %d\n", x); - showlist (The first, second, and third items.); - report (x>y, "x is %d but y is %d", x, y); -} - -// Check long long types. -#define BIG64 18446744073709551615ull -#define BIG32 4294967295ul -#define BIG_OK (BIG64 / BIG32 == 4294967297ull && BIG64 % BIG32 == 0) -#if !BIG_OK - #error "your preprocessor is broken" -#endif -#if BIG_OK -#else - #error "your preprocessor is broken" -#endif -static long long int bignum = -9223372036854775807LL; -static unsigned long long int ubignum = BIG64; - -struct incomplete_array -{ - int datasize; - double data[]; -}; - -struct named_init { - int number; - const wchar_t *name; - double average; -}; - -typedef const char *ccp; - -static inline int -test_restrict (ccp restrict text) -{ - // See if C++-style comments work. - // Iterate through items via the restricted pointer. - // Also check for declarations in for loops. - for (unsigned int i = 0; *(text+i) != '\''\0'\''; ++i) - continue; - return 0; -} - -// Check varargs and va_copy. -static bool -test_varargs (const char *format, ...) -{ - va_list args; - va_start (args, format); - va_list args_copy; - va_copy (args_copy, args); - - const char *str = ""; - int number = 0; - float fnumber = 0; - - while (*format) - { - switch (*format++) - { - case '\''s'\'': // string - str = va_arg (args_copy, const char *); - break; - case '\''d'\'': // int - number = va_arg (args_copy, int); - break; - case '\''f'\'': // float - fnumber = va_arg (args_copy, double); - break; - default: - break; - } - } - va_end (args_copy); - va_end (args); - - return *str && number && fnumber; -} -' - -# Test code for whether the C compiler supports C99 (body of main). -ac_c_conftest_c99_main=' - // Check bool. - _Bool success = false; - success |= (argc != 0); - - // Check restrict. - if (test_restrict ("String literal") == 0) - success = true; - char *restrict newvar = "Another string"; - - // Check varargs. - success &= test_varargs ("s, d'\'' f .", "string", 65, 34.234); - test_varargs_macros (); - - // Check flexible array members. - struct incomplete_array *ia = - malloc (sizeof (struct incomplete_array) + (sizeof (double) * 10)); - ia->datasize = 10; - for (int i = 0; i < ia->datasize; ++i) - ia->data[i] = i * 1.234; - - // Check named initializers. - struct named_init ni = { - .number = 34, - .name = L"Test wide string", - .average = 543.34343, - }; - - ni.number = 58; - - int dynamic_array[ni.number]; - dynamic_array[0] = argv[0][0]; - dynamic_array[ni.number - 1] = 543; - - // work around unused variable warnings - ok |= (!success || bignum == 0LL || ubignum == 0uLL || newvar[0] == '\''x'\'' - || dynamic_array[ni.number - 1] != 543); -' - -# Test code for whether the C compiler supports C11 (global declarations) -ac_c_conftest_c11_globals=' -// Does the compiler advertise C11 conformance? -#if !defined __STDC_VERSION__ || __STDC_VERSION__ < 201112L -# error "Compiler does not advertise C11 conformance" -#endif - -// Check _Alignas. -char _Alignas (double) aligned_as_double; -char _Alignas (0) no_special_alignment; -extern char aligned_as_int; -char _Alignas (0) _Alignas (int) aligned_as_int; - -// Check _Alignof. -enum -{ - int_alignment = _Alignof (int), - int_array_alignment = _Alignof (int[100]), - char_alignment = _Alignof (char) -}; -_Static_assert (0 < -_Alignof (int), "_Alignof is signed"); - -// Check _Noreturn. -int _Noreturn does_not_return (void) { for (;;) continue; } - -// Check _Static_assert. -struct test_static_assert -{ - int x; - _Static_assert (sizeof (int) <= sizeof (long int), - "_Static_assert does not work in struct"); - long int y; -}; - -// Check UTF-8 literals. -#define u8 syntax error! -char const utf8_literal[] = u8"happens to be ASCII" "another string"; - -// Check duplicate typedefs. -typedef long *long_ptr; -typedef long int *long_ptr; -typedef long_ptr long_ptr; - -// Anonymous structures and unions -- taken from C11 6.7.2.1 Example 1. -struct anonymous -{ - union { - struct { int i; int j; }; - struct { int k; long int l; } w; - }; - int m; -} v1; -' - -# Test code for whether the C compiler supports C11 (body of main). -ac_c_conftest_c11_main=' - _Static_assert ((offsetof (struct anonymous, i) - == offsetof (struct anonymous, w.k)), - "Anonymous union alignment botch"); - v1.i = 2; - v1.w.k = 5; - ok |= v1.i != 5; -' - -# Test code for whether the C compiler supports C11 (complete). -ac_c_conftest_c11_program="${ac_c_conftest_c89_globals} -${ac_c_conftest_c99_globals} -${ac_c_conftest_c11_globals} - -int -main (int argc, char **argv) -{ - int ok = 0; - ${ac_c_conftest_c89_main} - ${ac_c_conftest_c99_main} - ${ac_c_conftest_c11_main} - return ok; -} -" - -# Test code for whether the C compiler supports C99 (complete). -ac_c_conftest_c99_program="${ac_c_conftest_c89_globals} -${ac_c_conftest_c99_globals} - -int -main (int argc, char **argv) -{ - int ok = 0; - ${ac_c_conftest_c89_main} - ${ac_c_conftest_c99_main} - return ok; -} -" - -# Test code for whether the C compiler supports C89 (complete). -ac_c_conftest_c89_program="${ac_c_conftest_c89_globals} - -int -main (int argc, char **argv) -{ - int ok = 0; - ${ac_c_conftest_c89_main} - return ok; -} -" - -# Check that the precious variables saved in the cache have kept the same -# value. -ac_cache_corrupted=false -for ac_var in $ac_precious_vars; do - eval ac_old_set=\$ac_cv_env_${ac_var}_set - eval ac_new_set=\$ac_env_${ac_var}_set - eval ac_old_val=\$ac_cv_env_${ac_var}_value - eval ac_new_val=\$ac_env_${ac_var}_value - case $ac_old_set,$ac_new_set in - set,) - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 -printf "%s\n" "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} - ac_cache_corrupted=: ;; - ,set) - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 -printf "%s\n" "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} - ac_cache_corrupted=: ;; - ,);; - *) - if test "x$ac_old_val" != "x$ac_new_val"; then - # differences in whitespace do not lead to failure. - ac_old_val_w=`echo x $ac_old_val` - ac_new_val_w=`echo x $ac_new_val` - if test "$ac_old_val_w" != "$ac_new_val_w"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 -printf "%s\n" "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} - ac_cache_corrupted=: - else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 -printf "%s\n" "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} - eval $ac_var=\$ac_old_val - fi - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 -printf "%s\n" "$as_me: former value: \`$ac_old_val'" >&2;} - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 -printf "%s\n" "$as_me: current value: \`$ac_new_val'" >&2;} - fi;; - esac - # Pass precious variables to config.status. - if test "$ac_new_set" = set; then - case $ac_new_val in - *\'*) ac_arg=$ac_var=`printf "%s\n" "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; - *) ac_arg=$ac_var=$ac_new_val ;; - esac - case " $ac_configure_args " in - *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. - *) as_fn_append ac_configure_args " '$ac_arg'" ;; - esac - fi -done -if $ac_cache_corrupted; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 -printf "%s\n" "$as_me: error: changes in the environment can compromise the build" >&2;} - as_fn_error $? "run \`${MAKE-make} distclean' and/or \`rm $cache_file' - and start over" "$LINENO" 5 -fi -## -------------------- ## -## Main body of script. ## -## -------------------- ## - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - - - - - - - -# Check whether --with-rlm_couchbase was given. -if test ${with_rlm_couchbase+y} -then : - withval=$with_rlm_couchbase; -fi - - - - -fail= -fr_status= -fr_features= -: > "config.report" -: > "config.report.tmp" - - - -if test x"$with_rlm_couchbase" != xno; then - - - - - - - - - - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. -set dummy ${ac_tool_prefix}gcc; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_CC="${ac_tool_prefix}gcc" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -printf "%s\n" "$CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_CC"; then - ac_ct_CC=$CC - # Extract the first word of "gcc", so it can be a program name with args. -set dummy gcc; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_ac_ct_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_ac_ct_CC="gcc" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -printf "%s\n" "$ac_ct_CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -else - CC="$ac_cv_prog_CC" -fi - -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. -set dummy ${ac_tool_prefix}cc; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_CC="${ac_tool_prefix}cc" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -printf "%s\n" "$CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - - fi -fi -if test -z "$CC"; then - # Extract the first word of "cc", so it can be a program name with args. -set dummy cc; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else - ac_prog_rejected=no -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - if test "$as_dir$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then - ac_prog_rejected=yes - continue - fi - ac_cv_prog_CC="cc" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -if test $ac_prog_rejected = yes; then - # We found a bogon in the path, so make sure we never use it. - set dummy $ac_cv_prog_CC - shift - if test $# != 0; then - # We chose a different compiler from the bogus one. - # However, it has the same basename, so the bogon will be chosen - # first if we set CC to just the basename; use the full file name. - shift - ac_cv_prog_CC="$as_dir$ac_word${1+' '}$@" - fi -fi -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -printf "%s\n" "$CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - -fi -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - for ac_prog in cl.exe - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_CC="$ac_tool_prefix$ac_prog" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -printf "%s\n" "$CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - - test -n "$CC" && break - done -fi -if test -z "$CC"; then - ac_ct_CC=$CC - for ac_prog in cl.exe -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_ac_ct_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_ac_ct_CC="$ac_prog" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -printf "%s\n" "$ac_ct_CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - - test -n "$ac_ct_CC" && break -done - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -fi - -fi -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}clang", so it can be a program name with args. -set dummy ${ac_tool_prefix}clang; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_CC="${ac_tool_prefix}clang" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -printf "%s\n" "$CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_CC"; then - ac_ct_CC=$CC - # Extract the first word of "clang", so it can be a program name with args. -set dummy clang; ac_word=$2 -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -printf %s "checking for $ac_word... " >&6; } -if test ${ac_cv_prog_ac_ct_CC+y} -then : - printf %s "(cached) " >&6 -else $as_nop - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then - ac_cv_prog_ac_ct_CC="clang" - printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -printf "%s\n" "$ac_ct_CC" >&6; } -else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -else - CC="$ac_cv_prog_CC" -fi - -fi - - -test -z "$CC" && { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "no acceptable C compiler found in \$PATH -See \`config.log' for more details" "$LINENO" 5; } - -# Provide some information about the compiler. -printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 -set X $ac_compile -ac_compiler=$2 -for ac_option in --version -v -V -qversion -version; do - { { ac_try="$ac_compiler $ac_option >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_compiler $ac_option >&5") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - sed '10a\ -... rest of stderr output deleted ... - 10q' conftest.err >conftest.er1 - cat conftest.er1 >&5 - fi - rm -f conftest.er1 conftest.err - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -done - -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main (void) -{ - - ; - return 0; -} -_ACEOF -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" -# Try to create an executable without -o first, disregard a.out. -# It will help us diagnose broken compilers, and finding out an intuition -# of exeext. -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 -printf %s "checking whether the C compiler works... " >&6; } -ac_link_default=`printf "%s\n" "$ac_link" | sed 's/ -o *conftest[^ ]*//'` - -# The possible output files: -ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" - -ac_rmfiles= -for ac_file in $ac_files -do - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - * ) ac_rmfiles="$ac_rmfiles $ac_file";; - esac -done -rm -f $ac_rmfiles - -if { { ac_try="$ac_link_default" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_link_default") 2>&5 - ac_status=$? - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -then : - # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. -# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' -# in a Makefile. We should not override ac_cv_exeext if it was cached, -# so that the user can short-circuit this test for compilers unknown to -# Autoconf. -for ac_file in $ac_files '' -do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) - ;; - [ab].out ) - # We found the default executable, but exeext='' is most - # certainly right. - break;; - *.* ) - if test ${ac_cv_exeext+y} && test "$ac_cv_exeext" != no; - then :; else - ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - fi - # We set ac_cv_exeext here because the later test for it is not - # safe: cross compilers may not add the suffix if given an `-o' - # argument, so we may need to know it at that point already. - # Even if this section looks crufty: it has the advantage of - # actually working. - break;; - * ) - break;; - esac -done -test "$ac_cv_exeext" = no && ac_cv_exeext= - -else $as_nop - ac_file='' -fi -if test -z "$ac_file" -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -printf "%s\n" "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error 77 "C compiler cannot create executables -See \`config.log' for more details" "$LINENO" 5; } -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } -fi -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 -printf %s "checking for C compiler default output file name... " >&6; } -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 -printf "%s\n" "$ac_file" >&6; } -ac_exeext=$ac_cv_exeext - -rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out -ac_clean_files=$ac_clean_files_save -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 -printf %s "checking for suffix of executables... " >&6; } -if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -then : - # If both `conftest.exe' and `conftest' are `present' (well, observable) -# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will -# work properly (i.e., refer to `conftest.exe'), while it won't with -# `rm'. -for ac_file in conftest.exe conftest conftest.*; do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - break;; - * ) break;; - esac -done -else $as_nop - { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details" "$LINENO" 5; } -fi -rm -f conftest conftest$ac_cv_exeext -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 -printf "%s\n" "$ac_cv_exeext" >&6; } - -rm -f conftest.$ac_ext -EXEEXT=$ac_cv_exeext -ac_exeext=$EXEEXT -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -int -main (void) -{ -FILE *f = fopen ("conftest.out", "w"); - return ferror (f) || fclose (f) != 0; - - ; - return 0; -} -_ACEOF -ac_clean_files="$ac_clean_files conftest.out" -# Check that the compiler produces executables we can run. If not, either -# the compiler is broken, or we cross compile. -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 -printf %s "checking whether we are cross compiling... " >&6; } -if test "$cross_compiling" != yes; then - { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } - if { ac_try='./conftest$ac_cv_exeext' - { { case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; }; then - cross_compiling=no - else - if test "$cross_compiling" = maybe; then - cross_compiling=yes - else - { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error 77 "cannot run C compiled programs. -If you meant to cross compile, use \`--host'. -See \`config.log' for more details" "$LINENO" 5; } - fi - fi -fi -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 -printf "%s\n" "$cross_compiling" >&6; } - -rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out -ac_clean_files=$ac_clean_files_save -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 -printf %s "checking for suffix of object files... " >&6; } -if test ${ac_cv_objext+y} -then : - printf %s "(cached) " >&6 -else $as_nop - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main (void) -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.o conftest.obj -if { { ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -printf "%s\n" "$ac_try_echo"; } >&5 - (eval "$ac_compile") 2>&5 - ac_status=$? - printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -then : - for ac_file in conftest.o conftest.obj conftest.*; do - test -f "$ac_file" || continue; - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; - *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` - break;; - esac -done -else $as_nop - printf "%s\n" "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot compute suffix of object files: cannot compile -See \`config.log' for more details" "$LINENO" 5; } -fi -rm -f conftest.$ac_cv_objext conftest.$ac_ext -fi -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 -printf "%s\n" "$ac_cv_objext" >&6; } -OBJEXT=$ac_cv_objext -ac_objext=$OBJEXT -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the compiler supports GNU C" >&5 -printf %s "checking whether the compiler supports GNU C... " >&6; } -if test ${ac_cv_c_compiler_gnu+y} -then : - printf %s "(cached) " >&6 -else $as_nop - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main (void) -{ -#ifndef __GNUC__ - choke me -#endif - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - ac_compiler_gnu=yes -else $as_nop - ac_compiler_gnu=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -ac_cv_c_compiler_gnu=$ac_compiler_gnu - -fi -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 -printf "%s\n" "$ac_cv_c_compiler_gnu" >&6; } -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -if test $ac_compiler_gnu = yes; then - GCC=yes -else - GCC= -fi -ac_test_CFLAGS=${CFLAGS+y} -ac_save_CFLAGS=$CFLAGS -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 -printf %s "checking whether $CC accepts -g... " >&6; } -if test ${ac_cv_prog_cc_g+y} -then : - printf %s "(cached) " >&6 -else $as_nop - ac_save_c_werror_flag=$ac_c_werror_flag - ac_c_werror_flag=yes - ac_cv_prog_cc_g=no - CFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main (void) -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - ac_cv_prog_cc_g=yes -else $as_nop - CFLAGS="" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main (void) -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - -else $as_nop - ac_c_werror_flag=$ac_save_c_werror_flag - CFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main (void) -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - ac_cv_prog_cc_g=yes -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext - ac_c_werror_flag=$ac_save_c_werror_flag -fi -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 -printf "%s\n" "$ac_cv_prog_cc_g" >&6; } -if test $ac_test_CFLAGS; then - CFLAGS=$ac_save_CFLAGS -elif test $ac_cv_prog_cc_g = yes; then - if test "$GCC" = yes; then - CFLAGS="-g -O2" - else - CFLAGS="-g" - fi -else - if test "$GCC" = yes; then - CFLAGS="-O2" - else - CFLAGS= - fi -fi -ac_prog_cc_stdc=no -if test x$ac_prog_cc_stdc = xno -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C11 features" >&5 -printf %s "checking for $CC option to enable C11 features... " >&6; } -if test ${ac_cv_prog_cc_c11+y} -then : - printf %s "(cached) " >&6 -else $as_nop - ac_cv_prog_cc_c11=no -ac_save_CC=$CC -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -$ac_c_conftest_c11_program -_ACEOF -for ac_arg in '' -std=gnu11 -do - CC="$ac_save_CC $ac_arg" - if ac_fn_c_try_compile "$LINENO" -then : - ac_cv_prog_cc_c11=$ac_arg -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam - test "x$ac_cv_prog_cc_c11" != "xno" && break -done -rm -f conftest.$ac_ext -CC=$ac_save_CC -fi - -if test "x$ac_cv_prog_cc_c11" = xno -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 -printf "%s\n" "unsupported" >&6; } -else $as_nop - if test "x$ac_cv_prog_cc_c11" = x -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 -printf "%s\n" "none needed" >&6; } -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c11" >&5 -printf "%s\n" "$ac_cv_prog_cc_c11" >&6; } - CC="$CC $ac_cv_prog_cc_c11" -fi - ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c11 - ac_prog_cc_stdc=c11 -fi -fi -if test x$ac_prog_cc_stdc = xno -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C99 features" >&5 -printf %s "checking for $CC option to enable C99 features... " >&6; } -if test ${ac_cv_prog_cc_c99+y} -then : - printf %s "(cached) " >&6 -else $as_nop - ac_cv_prog_cc_c99=no -ac_save_CC=$CC -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -$ac_c_conftest_c99_program -_ACEOF -for ac_arg in '' -std=gnu99 -std=c99 -c99 -qlanglvl=extc1x -qlanglvl=extc99 -AC99 -D_STDC_C99= -do - CC="$ac_save_CC $ac_arg" - if ac_fn_c_try_compile "$LINENO" -then : - ac_cv_prog_cc_c99=$ac_arg -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam - test "x$ac_cv_prog_cc_c99" != "xno" && break -done -rm -f conftest.$ac_ext -CC=$ac_save_CC -fi - -if test "x$ac_cv_prog_cc_c99" = xno -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 -printf "%s\n" "unsupported" >&6; } -else $as_nop - if test "x$ac_cv_prog_cc_c99" = x -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 -printf "%s\n" "none needed" >&6; } -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c99" >&5 -printf "%s\n" "$ac_cv_prog_cc_c99" >&6; } - CC="$CC $ac_cv_prog_cc_c99" -fi - ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c99 - ac_prog_cc_stdc=c99 -fi -fi -if test x$ac_prog_cc_stdc = xno -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C89 features" >&5 -printf %s "checking for $CC option to enable C89 features... " >&6; } -if test ${ac_cv_prog_cc_c89+y} -then : - printf %s "(cached) " >&6 -else $as_nop - ac_cv_prog_cc_c89=no -ac_save_CC=$CC -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -$ac_c_conftest_c89_program -_ACEOF -for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" -do - CC="$ac_save_CC $ac_arg" - if ac_fn_c_try_compile "$LINENO" -then : - ac_cv_prog_cc_c89=$ac_arg -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam - test "x$ac_cv_prog_cc_c89" != "xno" && break -done -rm -f conftest.$ac_ext -CC=$ac_save_CC -fi - -if test "x$ac_cv_prog_cc_c89" = xno -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 -printf "%s\n" "unsupported" >&6; } -else $as_nop - if test "x$ac_cv_prog_cc_c89" = x -then : - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 -printf "%s\n" "none needed" >&6; } -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 -printf "%s\n" "$ac_cv_prog_cc_c89" >&6; } - CC="$CC $ac_cv_prog_cc_c89" -fi - ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c89 - ac_prog_cc_stdc=c89 -fi -fi - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 -printf %s "checking how to run the C preprocessor... " >&6; } -# On Suns, sometimes $CPP names a directory. -if test -n "$CPP" && test -d "$CPP"; then - CPP= -fi -if test -z "$CPP"; then - if test ${ac_cv_prog_CPP+y} -then : - printf %s "(cached) " >&6 -else $as_nop - # Double quotes because $CC needs to be expanded - for CPP in "$CC -E" "$CC -E -traditional-cpp" cpp /lib/cpp - do - ac_preproc_ok=false -for ac_c_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include - Syntax error -_ACEOF -if ac_fn_c_try_cpp "$LINENO" -then : - -else $as_nop - # Broken: fails on valid input. -continue -fi -rm -f conftest.err conftest.i conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -_ACEOF -if ac_fn_c_try_cpp "$LINENO" -then : - # Broken: success on invalid input. -continue -else $as_nop - # Passes both tests. -ac_preproc_ok=: -break -fi -rm -f conftest.err conftest.i conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.i conftest.err conftest.$ac_ext -if $ac_preproc_ok -then : - break -fi - - done - ac_cv_prog_CPP=$CPP - -fi - CPP=$ac_cv_prog_CPP -else - ac_cv_prog_CPP=$CPP -fi -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 -printf "%s\n" "$CPP" >&6; } -ac_preproc_ok=false -for ac_c_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include - Syntax error -_ACEOF -if ac_fn_c_try_cpp "$LINENO" -then : - -else $as_nop - # Broken: fails on valid input. -continue -fi -rm -f conftest.err conftest.i conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -_ACEOF -if ac_fn_c_try_cpp "$LINENO" -then : - # Broken: success on invalid input. -continue -else $as_nop - # Passes both tests. -ac_preproc_ok=: -break -fi -rm -f conftest.err conftest.i conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.i conftest.err conftest.$ac_ext -if $ac_preproc_ok -then : - -else $as_nop - { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5; } -fi - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - -libcouchbase_include_dir= - -# Check whether --with-libcouchbase-include-dir was given. -if test ${with_libcouchbase_include_dir+y} -then : - withval=$with_libcouchbase_include_dir; case "$withval" in - no) - as_fn_error $? "Need libcouchbase-include-dir" "$LINENO" 5 - ;; - yes) - ;; - *) - libcouchbase_include_dir="$withval" - ;; - esac -fi - - -libcouchbase_lib_dir= - -# Check whether --with-libcouchbase-lib-dir was given. -if test ${with_libcouchbase_lib_dir+y} -then : - withval=$with_libcouchbase_lib_dir; case "$withval" in - no) - as_fn_error $? "Need libcouchbase-lib-dir" "$LINENO" 5 - ;; - yes) - ;; - *) - libcouchbase_lib_dir="$withval" - ;; - esac -fi - - - -# Check whether --with-libcouchbase-dir was given. -if test ${with_libcouchbase_dir+y} -then : - withval=$with_libcouchbase_dir; case "$withval" in - no) - as_fn_error $? "Need libcouchbase-dir" "$LINENO" 5 - ;; - yes) - ;; - *) - libcouchbase_lib_dir="$withval/lib" - libcouchbase_include_dir="$withval/include" - ;; - esac -fi - - - -smart_try_dir="$libcouchbase_include_dir" - - - -ac_safe=`echo "libcouchbase/couchbase.h" | sed 'y%./+-%__pm%'` - -if test "x" = "x"; then - sm_pkg=`echo "${ac_safe}" | sed 's/.h//;s/^lib//'` -else - sm_pkg="" -fi - -old_CPPFLAGS="$CPPFLAGS" -smart_include_dir="/usr/local/include /opt/include /usr/local/${sm_pkg}/include /opt/homebrew/include /opt/homebrew/opt/${sm_pkg}/include" - -_smart_try_dir= -_smart_include_dir= - -for _prefix in $smart_prefix ""; do -for _dir in $smart_try_dir; do - _smart_try_dir="${_smart_try_dir} ${_dir}/${_prefix}" -done - -for _dir in $smart_include_dir; do - _smart_include_dir="${_smart_include_dir} ${_dir}/${_prefix}" -done -done - -if test "x$_smart_try_dir" != "x"; then -for try in $_smart_try_dir; do - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcouchbase/couchbase.h in $try" >&5 -printf %s "checking for libcouchbase/couchbase.h in $try... " >&6; } - CPPFLAGS="-isystem $try $old_CPPFLAGS" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - - #include - -int -main (void) -{ - - int a = 1; - - - ; - return 0; -} - -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - - smart_include="-isystem $try" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - break - -else $as_nop - - smart_include= - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } - -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -done -CPPFLAGS="$old_CPPFLAGS" -fi - -if test "x$smart_include" = "x"; then -for _prefix in $smart_prefix; do - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ${_prefix}/libcouchbase/couchbase.h" >&5 -printf %s "checking for ${_prefix}/libcouchbase/couchbase.h... " >&6; } - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - - #include - -int -main (void) -{ - - int a = 1; - - - ; - return 0; -} - -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - - smart_include="-isystem ${_prefix}/" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - break - -else $as_nop - - smart_include= - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } - -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -done -fi - -if test "x$smart_include" = "x"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcouchbase/couchbase.h" >&5 -printf %s "checking for libcouchbase/couchbase.h... " >&6; } - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - - #include - -int -main (void) -{ - - int a = 1; - - - ; - return 0; -} - -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - - smart_include=" " - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - break - -else $as_nop - - smart_include= - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } - -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -fi - -if test "x$smart_include" = "x"; then -for try in $_smart_include_dir; do - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcouchbase/couchbase.h in $try" >&5 -printf %s "checking for libcouchbase/couchbase.h in $try... " >&6; } - CPPFLAGS="-isystem $try $old_CPPFLAGS" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - - #include - -int -main (void) -{ - - int a = 1; - - - ; - return 0; -} - -_ACEOF -if ac_fn_c_try_compile "$LINENO" -then : - - smart_include="-isystem $try" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - break - -else $as_nop - - smart_include= - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } - -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext -done -CPPFLAGS="$old_CPPFLAGS" -fi - -if test "x$smart_include" != "x"; then -eval "ac_cv_header_$ac_safe=yes" -CPPFLAGS="$smart_include $old_CPPFLAGS" -SMART_CPPFLAGS="$smart_include $SMART_CPPFLAGS" -fi - -smart_prefix= - -if test "x$ac_cv_header_libcouchbase_couchbase_h" != "xyes"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: libcouchbase headers not found. Use --with-libcouchbase-include-dir=." >&5 -printf "%s\n" "$as_me: WARNING: libcouchbase headers not found. Use --with-libcouchbase-include-dir=." >&2;} - -fail="$fail couchbase.h" - -fi - - -smart_try_dir="$libcouchbase_lib_dir" - - -sm_lib_safe=`echo "couchbase" | sed 'y%./+-%__p_%'` -sm_func_safe=`echo "lcb_get_version" | sed 'y%./+-%__p_%'` - -if test "x" = "x"; then - sm_pkg="${sm_lib_safe}" -else - sm_pkg="" -fi - -old_LIBS="$LIBS" -old_CPPFLAGS="$CPPFLAGS" -smart_lib= -smart_ldflags= -smart_lib_dir="/usr/local/lib /opt/lib /usr/local/${sm_pkg}/lib /opt/homebrew/lib /opt/homebrew/opt/${sm_pkg}/lib" - -if test "x$smart_try_dir" != "x"; then -for try in $smart_try_dir; do - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for lcb_get_version in -lcouchbase in $try" >&5 -printf %s "checking for lcb_get_version in -lcouchbase in $try... " >&6; } - LIBS="-lcouchbase $old_LIBS" - CPPFLAGS="-L$try -Wl,-rpath,$try $old_CPPFLAGS" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -extern char lcb_get_version(); -int -main (void) -{ -lcb_get_version() - ; - return 0; -} -_ACEOF -if ac_fn_c_try_link "$LINENO" -then : - - smart_lib="-lcouchbase" - smart_ldflags="-L$try -Wl,-rpath,$try" - smart_ld_found="$try" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - break - -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam \ - conftest$ac_exeext conftest.$ac_ext -done -LIBS="$old_LIBS" -CPPFLAGS="$old_CPPFLAGS" -fi - -if test "x$smart_lib" = "x"; then -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for lcb_get_version in -lcouchbase" >&5 -printf %s "checking for lcb_get_version in -lcouchbase... " >&6; } -LIBS="-lcouchbase $old_LIBS" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -extern char lcb_get_version(); -int -main (void) -{ -lcb_get_version() - ; - return 0; -} -_ACEOF -if ac_fn_c_try_link "$LINENO" -then : - - smart_lib="-lcouchbase" - smart_ld_found="" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam \ - conftest$ac_exeext conftest.$ac_ext -LIBS="$old_LIBS" -fi - -if test "x$smart_lib" = "x"; then -for try in $smart_lib_dir; do - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for lcb_get_version in -lcouchbase in $try" >&5 -printf %s "checking for lcb_get_version in -lcouchbase in $try... " >&6; } - LIBS="-lcouchbase $old_LIBS" - CPPFLAGS="-L$try -Wl,-rpath,$try $old_CPPFLAGS" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -extern char lcb_get_version(); -int -main (void) -{ -lcb_get_version() - ; - return 0; -} -_ACEOF -if ac_fn_c_try_link "$LINENO" -then : - - smart_lib="-lcouchbase" - smart_ldflags="-L$try -Wl,-rpath,$try" - smart_ld_found="$try" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -printf "%s\n" "yes" >&6; } - break - -else $as_nop - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 -printf "%s\n" "no" >&6; } -fi -rm -f core conftest.err conftest.$ac_objext conftest.beam \ - conftest$ac_exeext conftest.$ac_ext -done -LIBS="$old_LIBS" -CPPFLAGS="$old_CPPFLAGS" -fi - -if test "x$smart_lib" != "x"; then -eval "ac_cv_lib_${sm_lib_safe}_${sm_func_safe}=yes" -LIBS="$smart_ldflags $smart_lib $old_LIBS" -SMART_LIBS="$smart_ldflags $smart_lib $SMART_LIBS" -SMART_LD_FOUND="$smart_ld_found" -fi - -if test "x$ac_cv_lib_couchbase_lcb_get_version" != "xyes"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: libcouchbase libraries not found. Use --with-libcouchbase-lib-dir=." >&5 -printf "%s\n" "$as_me: WARNING: libcouchbase libraries not found. Use --with-libcouchbase-lib-dir=." >&2;} - -fail="$fail libcouchbase" - -fi - - - targetname=rlm_couchbase -else - targetname= - echo \*\*\* module rlm_couchbase is disabled. - - -fr_status="disabled" - -fi - -if test x"$fail" != x""; then - targetname="" - - - if test x"${enable_strict_dependencies}" = x"yes"; then - as_fn_error $? "set --without-rlm_couchbase to disable it explicitly." "$LINENO" 5 - else - - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: silently not building rlm_couchbase." >&5 -printf "%s\n" "$as_me: WARNING: silently not building rlm_couchbase." >&2;} - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: FAILURE: rlm_couchbase requires: $fail." >&5 -printf "%s\n" "$as_me: WARNING: FAILURE: rlm_couchbase requires: $fail." >&2;}; - fail="$(echo $fail)" - - -fr_status="skipping (requires $fail)" - - fr_features= - - fi - -else - - -fr_status="OK" - -fi - -if test x"$fr_features" = x""; then - $as_echo "$fr_status" > "config.report" -else - $as_echo_n "$fr_status ... " > "config.report" - cat "config.report.tmp" >> "config.report" -fi - -rm "config.report.tmp" - - - - -mod_ldflags="${SMART_LIBS}" -mod_cflags="${SMART_CPPFLAGS}" - - - - -ac_config_headers="$ac_config_headers config.h" - -ac_config_files="$ac_config_files all.mk" - -cat >confcache <<\_ACEOF -# This file is a shell script that caches the results of configure -# tests run on this system so they can be shared between configure -# scripts and configure runs, see configure's option --config-cache. -# It is not useful on other systems. If it contains results you don't -# want to keep, you may remove or edit it. -# -# config.status only pays attention to the cache file if you give it -# the --recheck option to rerun configure. -# -# `ac_cv_env_foo' variables (set or unset) will be overridden when -# loading this file, other *unset* `ac_cv_foo' will be assigned the -# following values. - -_ACEOF - -# The following way of writing the cache mishandles newlines in values, -# but we know of no workaround that is simple, portable, and efficient. -# So, we kill variables containing newlines. -# Ultrix sh set writes to stderr and can't be redirected directly, -# and sets the high bit in the cache file unless we assign to the vars. -( - for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do - eval ac_val=\$$ac_var - case $ac_val in #( - *${as_nl}*) - case $ac_var in #( - *_cv_*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 -printf "%s\n" "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; - esac - case $ac_var in #( - _ | IFS | as_nl) ;; #( - BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( - *) { eval $ac_var=; unset $ac_var;} ;; - esac ;; - esac - done - - (set) 2>&1 | - case $as_nl`(ac_space=' '; set) 2>&1` in #( - *${as_nl}ac_space=\ *) - # `set' does not quote correctly, so add quotes: double-quote - # substitution turns \\\\ into \\, and sed turns \\ into \. - sed -n \ - "s/'/'\\\\''/g; - s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" - ;; #( - *) - # `set' quotes correctly as required by POSIX, so do not add quotes. - sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" - ;; - esac | - sort -) | - sed ' - /^ac_cv_env_/b end - t clear - :clear - s/^\([^=]*\)=\(.*[{}].*\)$/test ${\1+y} || &/ - t end - s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ - :end' >>confcache -if diff "$cache_file" confcache >/dev/null 2>&1; then :; else - if test -w "$cache_file"; then - if test "x$cache_file" != "x/dev/null"; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 -printf "%s\n" "$as_me: updating cache $cache_file" >&6;} - if test ! -f "$cache_file" || test -h "$cache_file"; then - cat confcache >"$cache_file" - else - case $cache_file in #( - */* | ?:*) - mv -f confcache "$cache_file"$$ && - mv -f "$cache_file"$$ "$cache_file" ;; #( - *) - mv -f confcache "$cache_file" ;; - esac - fi - fi - else - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 -printf "%s\n" "$as_me: not updating unwritable cache $cache_file" >&6;} - fi -fi -rm -f confcache - -test "x$prefix" = xNONE && prefix=$ac_default_prefix -# Let make expand exec_prefix. -test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' - -DEFS=-DHAVE_CONFIG_H - -ac_libobjs= -ac_ltlibobjs= -U= -for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue - # 1. Remove the extension, and $U if already installed. - ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' - ac_i=`printf "%s\n" "$ac_i" | sed "$ac_script"` - # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR - # will be set to the directory where LIBOBJS objects are built. - as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" - as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' -done -LIBOBJS=$ac_libobjs - -LTLIBOBJS=$ac_ltlibobjs - - - -: "${CONFIG_STATUS=./config.status}" -ac_write_fail=0 -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files $CONFIG_STATUS" -{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 -printf "%s\n" "$as_me: creating $CONFIG_STATUS" >&6;} -as_write_fail=0 -cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 -#! $SHELL -# Generated by $as_me. -# Run this file to recreate the current configuration. -# Compiler output produced by configure, useful for debugging -# configure, is in config.log if it exists. - -debug=false -ac_cs_recheck=false -ac_cs_silent=false - -SHELL=\${CONFIG_SHELL-$SHELL} -export SHELL -_ASEOF -cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 -## -------------------- ## -## M4sh Initialization. ## -## -------------------- ## - -# Be more Bourne compatible -DUALCASE=1; export DUALCASE # for MKS sh -as_nop=: -if test ${ZSH_VERSION+y} && (emulate sh) >/dev/null 2>&1 -then : - emulate sh - NULLCMD=: - # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else $as_nop - case `(set -o) 2>/dev/null` in #( - *posix*) : - set -o posix ;; #( - *) : - ;; -esac -fi - - - -# Reset variables that may have inherited troublesome values from -# the environment. - -# IFS needs to be set, to space, tab, and newline, in precisely that order. -# (If _AS_PATH_WALK were called with IFS unset, it would have the -# side effect of setting IFS to empty, thus disabling word splitting.) -# Quoting is to prevent editors from complaining about space-tab. -as_nl=' -' -export as_nl -IFS=" "" $as_nl" - -PS1='$ ' -PS2='> ' -PS4='+ ' - -# Ensure predictable behavior from utilities with locale-dependent output. -LC_ALL=C -export LC_ALL -LANGUAGE=C -export LANGUAGE - -# We cannot yet rely on "unset" to work, but we need these variables -# to be unset--not just set to an empty or harmless value--now, to -# avoid bugs in old shells (e.g. pre-3.0 UWIN ksh). This construct -# also avoids known problems related to "unset" and subshell syntax -# in other old shells (e.g. bash 2.01 and pdksh 5.2.14). -for as_var in BASH_ENV ENV MAIL MAILPATH CDPATH -do eval test \${$as_var+y} \ - && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : -done - -# Ensure that fds 0, 1, and 2 are open. -if (exec 3>&0) 2>/dev/null; then :; else exec 0&1) 2>/dev/null; then :; else exec 1>/dev/null; fi -if (exec 3>&2) ; then :; else exec 2>/dev/null; fi - -# The user is always right. -if ${PATH_SEPARATOR+false} :; then - PATH_SEPARATOR=: - (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { - (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || - PATH_SEPARATOR=';' - } -fi - - -# Find who we are. Look in the path if we contain no directory separator. -as_myself= -case $0 in #(( - *[\\/]* ) as_myself=$0 ;; - *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - case $as_dir in #((( - '') as_dir=./ ;; - */) ;; - *) as_dir=$as_dir/ ;; - esac - test -r "$as_dir$0" && as_myself=$as_dir$0 && break - done -IFS=$as_save_IFS - - ;; -esac -# We did not find ourselves, most probably we were run as `sh COMMAND' -# in which case we are not to be found in the path. -if test "x$as_myself" = x; then - as_myself=$0 -fi -if test ! -f "$as_myself"; then - printf "%s\n" "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 - exit 1 -fi - - - -# as_fn_error STATUS ERROR [LINENO LOG_FD] -# ---------------------------------------- -# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are -# provided, also output the error to LOG_FD, referencing LINENO. Then exit the -# script with STATUS, using 1 if that was 0. -as_fn_error () -{ - as_status=$1; test $as_status -eq 0 && as_status=1 - if test "$4"; then - as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 - fi - printf "%s\n" "$as_me: error: $2" >&2 - as_fn_exit $as_status -} # as_fn_error - - - -# as_fn_set_status STATUS -# ----------------------- -# Set $? to STATUS, without forking. -as_fn_set_status () -{ - return $1 -} # as_fn_set_status - -# as_fn_exit STATUS -# ----------------- -# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. -as_fn_exit () -{ - set +e - as_fn_set_status $1 - exit $1 -} # as_fn_exit - -# as_fn_unset VAR -# --------------- -# Portably unset VAR. -as_fn_unset () -{ - { eval $1=; unset $1;} -} -as_unset=as_fn_unset - -# as_fn_append VAR VALUE -# ---------------------- -# Append the text in VALUE to the end of the definition contained in VAR. Take -# advantage of any shell optimizations that allow amortized linear growth over -# repeated appends, instead of the typical quadratic growth present in naive -# implementations. -if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null -then : - eval 'as_fn_append () - { - eval $1+=\$2 - }' -else $as_nop - as_fn_append () - { - eval $1=\$$1\$2 - } -fi # as_fn_append - -# as_fn_arith ARG... -# ------------------ -# Perform arithmetic evaluation on the ARGs, and store the result in the -# global $as_val. Take advantage of shells that can avoid forks. The arguments -# must be portable across $(()) and expr. -if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null -then : - eval 'as_fn_arith () - { - as_val=$(( $* )) - }' -else $as_nop - as_fn_arith () - { - as_val=`expr "$@" || test $? -eq 1` - } -fi # as_fn_arith - - -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then - as_basename=basename -else - as_basename=false -fi - -if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then - as_dirname=dirname -else - as_dirname=false -fi - -as_me=`$as_basename -- "$0" || -$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -printf "%s\n" X/"$0" | - sed '/^.*\/\([^/][^/]*\)\/*$/{ - s//\1/ - q - } - /^X\/\(\/\/\)$/{ - s//\1/ - q - } - /^X\/\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - -# Avoid depending upon Character Ranges. -as_cr_letters='abcdefghijklmnopqrstuvwxyz' -as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -as_cr_Letters=$as_cr_letters$as_cr_LETTERS -as_cr_digits='0123456789' -as_cr_alnum=$as_cr_Letters$as_cr_digits - - -# Determine whether it's possible to make 'echo' print without a newline. -# These variables are no longer used directly by Autoconf, but are AC_SUBSTed -# for compatibility with existing Makefiles. -ECHO_C= ECHO_N= ECHO_T= -case `echo -n x` in #((((( --n*) - case `echo 'xy\c'` in - *c*) ECHO_T=' ';; # ECHO_T is single tab character. - xy) ECHO_C='\c';; - *) echo `echo ksh88 bug on AIX 6.1` > /dev/null - ECHO_T=' ';; - esac;; -*) - ECHO_N='-n';; -esac - -# For backward compatibility with old third-party macros, we provide -# the shell variables $as_echo and $as_echo_n. New code should use -# AS_ECHO(["message"]) and AS_ECHO_N(["message"]), respectively. -as_echo='printf %s\n' -as_echo_n='printf %s' - -rm -f conf$$ conf$$.exe conf$$.file -if test -d conf$$.dir; then - rm -f conf$$.dir/conf$$.file -else - rm -f conf$$.dir - mkdir conf$$.dir 2>/dev/null -fi -if (echo >conf$$.file) 2>/dev/null; then - if ln -s conf$$.file conf$$ 2>/dev/null; then - as_ln_s='ln -s' - # ... but there are two gotchas: - # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. - # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. - # In both cases, we have to default to `cp -pR'. - ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || - as_ln_s='cp -pR' - elif ln conf$$.file conf$$ 2>/dev/null; then - as_ln_s=ln - else - as_ln_s='cp -pR' - fi -else - as_ln_s='cp -pR' -fi -rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file -rmdir conf$$.dir 2>/dev/null - - -# as_fn_mkdir_p -# ------------- -# Create "$as_dir" as a directory, including parents if necessary. -as_fn_mkdir_p () -{ - - case $as_dir in #( - -*) as_dir=./$as_dir;; - esac - test -d "$as_dir" || eval $as_mkdir_p || { - as_dirs= - while :; do - case $as_dir in #( - *\'*) as_qdir=`printf "%s\n" "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( - *) as_qdir=$as_dir;; - esac - as_dirs="'$as_qdir' $as_dirs" - as_dir=`$as_dirname -- "$as_dir" || -$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$as_dir" : 'X\(//\)[^/]' \| \ - X"$as_dir" : 'X\(//\)$' \| \ - X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || -printf "%s\n" X"$as_dir" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - test -d "$as_dir" && break - done - test -z "$as_dirs" || eval "mkdir $as_dirs" - } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" - - -} # as_fn_mkdir_p -if mkdir -p . 2>/dev/null; then - as_mkdir_p='mkdir -p "$as_dir"' -else - test -d ./-p && rmdir ./-p - as_mkdir_p=false -fi - - -# as_fn_executable_p FILE -# ----------------------- -# Test if FILE is an executable regular file. -as_fn_executable_p () -{ - test -f "$1" && test -x "$1" -} # as_fn_executable_p -as_test_x='test -x' -as_executable_p=as_fn_executable_p - -# Sed expression to map a string onto a valid CPP name. -as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" - -# Sed expression to map a string onto a valid variable name. -as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" - - -exec 6>&1 -## ----------------------------------- ## -## Main body of $CONFIG_STATUS script. ## -## ----------------------------------- ## -_ASEOF -test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -# Save the log message, to keep $0 and so on meaningful, and to -# report actual input values of CONFIG_FILES etc. instead of their -# values after options handling. -ac_log=" -This file was extended by $as_me, which was -generated by GNU Autoconf 2.71. Invocation command line was - - CONFIG_FILES = $CONFIG_FILES - CONFIG_HEADERS = $CONFIG_HEADERS - CONFIG_LINKS = $CONFIG_LINKS - CONFIG_COMMANDS = $CONFIG_COMMANDS - $ $0 $@ - -on `(hostname || uname -n) 2>/dev/null | sed 1q` -" - -_ACEOF - -case $ac_config_files in *" -"*) set x $ac_config_files; shift; ac_config_files=$*;; -esac - -case $ac_config_headers in *" -"*) set x $ac_config_headers; shift; ac_config_headers=$*;; -esac - - -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -# Files that config.status was made for. -config_files="$ac_config_files" -config_headers="$ac_config_headers" - -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -ac_cs_usage="\ -\`$as_me' instantiates files and other configuration actions -from templates according to the current configuration. Unless the files -and actions are specified as TAGs, all are instantiated by default. - -Usage: $0 [OPTION]... [TAG]... - - -h, --help print this help, then exit - -V, --version print version number and configuration settings, then exit - --config print configuration, then exit - -q, --quiet, --silent - do not print progress messages - -d, --debug don't remove temporary files - --recheck update $as_me by reconfiguring in the same conditions - --file=FILE[:TEMPLATE] - instantiate the configuration file FILE - --header=FILE[:TEMPLATE] - instantiate the configuration header FILE - -Configuration files: -$config_files - -Configuration headers: -$config_headers - -Report bugs to the package provider." - -_ACEOF -ac_cs_config=`printf "%s\n" "$ac_configure_args" | sed "$ac_safe_unquote"` -ac_cs_config_escaped=`printf "%s\n" "$ac_cs_config" | sed "s/^ //; s/'/'\\\\\\\\''/g"` -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -ac_cs_config='$ac_cs_config_escaped' -ac_cs_version="\\ -config.status -configured by $0, generated by GNU Autoconf 2.71, - with options \\"\$ac_cs_config\\" - -Copyright (C) 2021 Free Software Foundation, Inc. -This config.status script is free software; the Free Software Foundation -gives unlimited permission to copy, distribute and modify it." - -ac_pwd='$ac_pwd' -srcdir='$srcdir' -test -n "\$AWK" || AWK=awk -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -# The default lists apply if the user does not specify any file. -ac_need_defaults=: -while test $# != 0 -do - case $1 in - --*=?*) - ac_option=`expr "X$1" : 'X\([^=]*\)='` - ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` - ac_shift=: - ;; - --*=) - ac_option=`expr "X$1" : 'X\([^=]*\)='` - ac_optarg= - ac_shift=: - ;; - *) - ac_option=$1 - ac_optarg=$2 - ac_shift=shift - ;; - esac - - case $ac_option in - # Handling of the options. - -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) - ac_cs_recheck=: ;; - --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) - printf "%s\n" "$ac_cs_version"; exit ;; - --config | --confi | --conf | --con | --co | --c ) - printf "%s\n" "$ac_cs_config"; exit ;; - --debug | --debu | --deb | --de | --d | -d ) - debug=: ;; - --file | --fil | --fi | --f ) - $ac_shift - case $ac_optarg in - *\'*) ac_optarg=`printf "%s\n" "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; - '') as_fn_error $? "missing file argument" ;; - esac - as_fn_append CONFIG_FILES " '$ac_optarg'" - ac_need_defaults=false;; - --header | --heade | --head | --hea ) - $ac_shift - case $ac_optarg in - *\'*) ac_optarg=`printf "%s\n" "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - as_fn_append CONFIG_HEADERS " '$ac_optarg'" - ac_need_defaults=false;; - --he | --h) - # Conflict between --help and --header - as_fn_error $? "ambiguous option: \`$1' -Try \`$0 --help' for more information.";; - --help | --hel | -h ) - printf "%s\n" "$ac_cs_usage"; exit ;; - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil | --si | --s) - ac_cs_silent=: ;; - - # This is an error. - -*) as_fn_error $? "unrecognized option: \`$1' -Try \`$0 --help' for more information." ;; - - *) as_fn_append ac_config_targets " $1" - ac_need_defaults=false ;; - - esac - shift -done - -ac_configure_extra_args= - -if $ac_cs_silent; then - exec 6>/dev/null - ac_configure_extra_args="$ac_configure_extra_args --silent" -fi - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -if \$ac_cs_recheck; then - set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion - shift - \printf "%s\n" "running CONFIG_SHELL=$SHELL \$*" >&6 - CONFIG_SHELL='$SHELL' - export CONFIG_SHELL - exec "\$@" -fi - -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -exec 5>>config.log -{ - echo - sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX -## Running $as_me. ## -_ASBOX - printf "%s\n" "$ac_log" -} >&5 - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 - -# Handling of arguments. -for ac_config_target in $ac_config_targets -do - case $ac_config_target in - "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;; - "all.mk") CONFIG_FILES="$CONFIG_FILES all.mk" ;; - - *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; - esac -done - - -# If the user did not use the arguments to specify the items to instantiate, -# then the envvar interface is used. Set only those that are not. -# We use the long form for the default assignment because of an extremely -# bizarre bug on SunOS 4.1.3. -if $ac_need_defaults; then - test ${CONFIG_FILES+y} || CONFIG_FILES=$config_files - test ${CONFIG_HEADERS+y} || CONFIG_HEADERS=$config_headers -fi - -# Have a temporary directory for convenience. Make it in the build tree -# simply because there is no reason against having it here, and in addition, -# creating and moving files from /tmp can sometimes cause problems. -# Hook for its removal unless debugging. -# Note that there is a small window in which the directory will not be cleaned: -# after its creation but before its name has been assigned to `$tmp'. -$debug || -{ - tmp= ac_tmp= - trap 'exit_status=$? - : "${ac_tmp:=$tmp}" - { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status -' 0 - trap 'as_fn_exit 1' 1 2 13 15 -} -# Create a (secure) tmp directory for tmp files. - -{ - tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && - test -d "$tmp" -} || -{ - tmp=./conf$$-$RANDOM - (umask 077 && mkdir "$tmp") -} || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 -ac_tmp=$tmp - -# Set up the scripts for CONFIG_FILES section. -# No need to generate them if there are no CONFIG_FILES. -# This happens for instance with `./config.status config.h'. -if test -n "$CONFIG_FILES"; then - - -ac_cr=`echo X | tr X '\015'` -# On cygwin, bash can eat \r inside `` if the user requested igncr. -# But we know of no other shell where ac_cr would be empty at this -# point, so we can use a bashism as a fallback. -if test "x$ac_cr" = x; then - eval ac_cr=\$\'\\r\' -fi -ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` -if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then - ac_cs_awk_cr='\\r' -else - ac_cs_awk_cr=$ac_cr -fi - -echo 'BEGIN {' >"$ac_tmp/subs1.awk" && -_ACEOF - - -{ - echo "cat >conf$$subs.awk <<_ACEOF" && - echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && - echo "_ACEOF" -} >conf$$subs.sh || - as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 -ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` -ac_delim='%!_!# ' -for ac_last_try in false false false false false :; do - . ./conf$$subs.sh || - as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 - - ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` - if test $ac_delim_n = $ac_delim_num; then - break - elif $ac_last_try; then - as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 - else - ac_delim="$ac_delim!$ac_delim _$ac_delim!! " - fi -done -rm -f conf$$subs.sh - -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && -_ACEOF -sed -n ' -h -s/^/S["/; s/!.*/"]=/ -p -g -s/^[^!]*!// -:repl -t repl -s/'"$ac_delim"'$// -t delim -:nl -h -s/\(.\{148\}\)..*/\1/ -t more1 -s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ -p -n -b repl -:more1 -s/["\\]/\\&/g; s/^/"/; s/$/"\\/ -p -g -s/.\{148\}// -t nl -:delim -h -s/\(.\{148\}\)..*/\1/ -t more2 -s/["\\]/\\&/g; s/^/"/; s/$/"/ -p -b -:more2 -s/["\\]/\\&/g; s/^/"/; s/$/"\\/ -p -g -s/.\{148\}// -t delim -' >$CONFIG_STATUS || ac_write_fail=1 -rm -f conf$$subs.awk -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -_ACAWK -cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && - for (key in S) S_is_set[key] = 1 - FS = "" - -} -{ - line = $ 0 - nfields = split(line, field, "@") - substed = 0 - len = length(field[1]) - for (i = 2; i < nfields; i++) { - key = field[i] - keylen = length(key) - if (S_is_set[key]) { - value = S[key] - line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) - len += length(value) + length(field[++i]) - substed = 1 - } else - len += 1 + keylen - } - - print line -} - -_ACAWK -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then - sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" -else - cat -fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ - || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 -_ACEOF - -# VPATH may cause trouble with some makes, so we remove sole $(srcdir), -# ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and -# trailing colons and then remove the whole line if VPATH becomes empty -# (actually we leave an empty line to preserve line numbers). -if test "x$srcdir" = x.; then - ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ -h -s/// -s/^/:/ -s/[ ]*$/:/ -s/:\$(srcdir):/:/g -s/:\${srcdir}:/:/g -s/:@srcdir@:/:/g -s/^:*// -s/:*$// -x -s/\(=[ ]*\).*/\1/ -G -s/\n// -s/^[^=]*=[ ]*$// -}' -fi - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -fi # test -n "$CONFIG_FILES" - -# Set up the scripts for CONFIG_HEADERS section. -# No need to generate them if there are no CONFIG_HEADERS. -# This happens for instance with `./config.status Makefile'. -if test -n "$CONFIG_HEADERS"; then -cat >"$ac_tmp/defines.awk" <<\_ACAWK || -BEGIN { -_ACEOF - -# Transform confdefs.h into an awk script `defines.awk', embedded as -# here-document in config.status, that substitutes the proper values into -# config.h.in to produce config.h. - -# Create a delimiter string that does not exist in confdefs.h, to ease -# handling of long lines. -ac_delim='%!_!# ' -for ac_last_try in false false :; do - ac_tt=`sed -n "/$ac_delim/p" confdefs.h` - if test -z "$ac_tt"; then - break - elif $ac_last_try; then - as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 - else - ac_delim="$ac_delim!$ac_delim _$ac_delim!! " - fi -done - -# For the awk script, D is an array of macro values keyed by name, -# likewise P contains macro parameters if any. Preserve backslash -# newline sequences. - -ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* -sed -n ' -s/.\{148\}/&'"$ac_delim"'/g -t rset -:rset -s/^[ ]*#[ ]*define[ ][ ]*/ / -t def -d -:def -s/\\$// -t bsnl -s/["\\]/\\&/g -s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ -D["\1"]=" \3"/p -s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p -d -:bsnl -s/["\\]/\\&/g -s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ -D["\1"]=" \3\\\\\\n"\\/p -t cont -s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p -t cont -d -:cont -n -s/.\{148\}/&'"$ac_delim"'/g -t clear -:clear -s/\\$// -t bsnlc -s/["\\]/\\&/g; s/^/"/; s/$/"/p -d -:bsnlc -s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p -b cont -' >$CONFIG_STATUS || ac_write_fail=1 - -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 - for (key in D) D_is_set[key] = 1 - FS = "" -} -/^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { - line = \$ 0 - split(line, arg, " ") - if (arg[1] == "#") { - defundef = arg[2] - mac1 = arg[3] - } else { - defundef = substr(arg[1], 2) - mac1 = arg[2] - } - split(mac1, mac2, "(") #) - macro = mac2[1] - prefix = substr(line, 1, index(line, defundef) - 1) - if (D_is_set[macro]) { - # Preserve the white space surrounding the "#". - print prefix "define", macro P[macro] D[macro] - next - } else { - # Replace #undef with comments. This is necessary, for example, - # in the case of _POSIX_SOURCE, which is predefined and required - # on some systems where configure will not decide to define it. - if (defundef == "undef") { - print "/*", prefix defundef, macro, "*/" - next - } - } -} -{ print } -_ACAWK -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 - as_fn_error $? "could not setup config headers machinery" "$LINENO" 5 -fi # test -n "$CONFIG_HEADERS" - - -eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS " -shift -for ac_tag -do - case $ac_tag in - :[FHLC]) ac_mode=$ac_tag; continue;; - esac - case $ac_mode$ac_tag in - :[FHL]*:*);; - :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; - :[FH]-) ac_tag=-:-;; - :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; - esac - ac_save_IFS=$IFS - IFS=: - set x $ac_tag - IFS=$ac_save_IFS - shift - ac_file=$1 - shift - - case $ac_mode in - :L) ac_source=$1;; - :[FH]) - ac_file_inputs= - for ac_f - do - case $ac_f in - -) ac_f="$ac_tmp/stdin";; - *) # Look for the file first in the build tree, then in the source tree - # (if the path is not absolute). The absolute path cannot be DOS-style, - # because $ac_f cannot contain `:'. - test -f "$ac_f" || - case $ac_f in - [\\/$]*) false;; - *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; - esac || - as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; - esac - case $ac_f in *\'*) ac_f=`printf "%s\n" "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac - as_fn_append ac_file_inputs " '$ac_f'" - done - - # Let's still pretend it is `configure' which instantiates (i.e., don't - # use $as_me), people would be surprised to read: - # /* config.h. Generated by config.status. */ - configure_input='Generated from '` - printf "%s\n" "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' - `' by configure.' - if test x"$ac_file" != x-; then - configure_input="$ac_file. $configure_input" - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 -printf "%s\n" "$as_me: creating $ac_file" >&6;} - fi - # Neutralize special characters interpreted by sed in replacement strings. - case $configure_input in #( - *\&* | *\|* | *\\* ) - ac_sed_conf_input=`printf "%s\n" "$configure_input" | - sed 's/[\\\\&|]/\\\\&/g'`;; #( - *) ac_sed_conf_input=$configure_input;; - esac - - case $ac_tag in - *:-:* | *:-) cat >"$ac_tmp/stdin" \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; - esac - ;; - esac - - ac_dir=`$as_dirname -- "$ac_file" || -$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$ac_file" : 'X\(//\)[^/]' \| \ - X"$ac_file" : 'X\(//\)$' \| \ - X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || -printf "%s\n" X"$ac_file" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - as_dir="$ac_dir"; as_fn_mkdir_p - ac_builddir=. - -case "$ac_dir" in -.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; -*) - ac_dir_suffix=/`printf "%s\n" "$ac_dir" | sed 's|^\.[\\/]||'` - # A ".." for each directory in $ac_dir_suffix. - ac_top_builddir_sub=`printf "%s\n" "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` - case $ac_top_builddir_sub in - "") ac_top_builddir_sub=. ac_top_build_prefix= ;; - *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; - esac ;; -esac -ac_abs_top_builddir=$ac_pwd -ac_abs_builddir=$ac_pwd$ac_dir_suffix -# for backward compatibility: -ac_top_builddir=$ac_top_build_prefix - -case $srcdir in - .) # We are building in place. - ac_srcdir=. - ac_top_srcdir=$ac_top_builddir_sub - ac_abs_top_srcdir=$ac_pwd ;; - [\\/]* | ?:[\\/]* ) # Absolute name. - ac_srcdir=$srcdir$ac_dir_suffix; - ac_top_srcdir=$srcdir - ac_abs_top_srcdir=$srcdir ;; - *) # Relative name. - ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix - ac_top_srcdir=$ac_top_build_prefix$srcdir - ac_abs_top_srcdir=$ac_pwd/$srcdir ;; -esac -ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix - - - case $ac_mode in - :F) - # - # CONFIG_FILE - # - -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -# If the template does not know about datarootdir, expand it. -# FIXME: This hack should be removed a few years after 2.60. -ac_datarootdir_hack=; ac_datarootdir_seen= -ac_sed_dataroot=' -/datarootdir/ { - p - q -} -/@datadir@/p -/@docdir@/p -/@infodir@/p -/@localedir@/p -/@mandir@/p' -case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in -*datarootdir*) ac_datarootdir_seen=yes;; -*@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 -printf "%s\n" "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 - ac_datarootdir_hack=' - s&@datadir@&$datadir&g - s&@docdir@&$docdir&g - s&@infodir@&$infodir&g - s&@localedir@&$localedir&g - s&@mandir@&$mandir&g - s&\\\${datarootdir}&$datarootdir&g' ;; -esac -_ACEOF - -# Neutralize VPATH when `$srcdir' = `.'. -# Shell code in configure.ac might set extrasub. -# FIXME: do we really want to maintain this feature? -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -ac_sed_extra="$ac_vpsub -$extrasub -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -:t -/@[a-zA-Z_][a-zA-Z_0-9]*@/!b -s|@configure_input@|$ac_sed_conf_input|;t t -s&@top_builddir@&$ac_top_builddir_sub&;t t -s&@top_build_prefix@&$ac_top_build_prefix&;t t -s&@srcdir@&$ac_srcdir&;t t -s&@abs_srcdir@&$ac_abs_srcdir&;t t -s&@top_srcdir@&$ac_top_srcdir&;t t -s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t -s&@builddir@&$ac_builddir&;t t -s&@abs_builddir@&$ac_abs_builddir&;t t -s&@abs_top_builddir@&$ac_abs_top_builddir&;t t -$ac_datarootdir_hack -" -eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ - >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - -test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && - { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && - { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ - "$ac_tmp/out"`; test -z "$ac_out"; } && - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' -which seems to be undefined. Please make sure it is defined" >&5 -printf "%s\n" "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' -which seems to be undefined. Please make sure it is defined" >&2;} - - rm -f "$ac_tmp/stdin" - case $ac_file in - -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; - *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; - esac \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - ;; - :H) - # - # CONFIG_HEADER - # - if test x"$ac_file" != x-; then - { - printf "%s\n" "/* $configure_input */" >&1 \ - && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" - } >"$ac_tmp/config.h" \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 -printf "%s\n" "$as_me: $ac_file is unchanged" >&6;} - else - rm -f "$ac_file" - mv "$ac_tmp/config.h" "$ac_file" \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - fi - else - printf "%s\n" "/* $configure_input */" >&1 \ - && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ - || as_fn_error $? "could not create -" "$LINENO" 5 - fi - ;; - - - esac - -done # for ac_tag - - -as_fn_exit 0 -_ACEOF -ac_clean_files=$ac_clean_files_save - -test $ac_write_fail = 0 || - as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 - - -# configure is writing to config.log, and then calls config.status. -# config.status does its own redirection, appending to config.log. -# Unfortunately, on DOS this fails, as config.log is still kept open -# by configure, so config.status won't be able to write to it; its -# output is simply discarded. So we exec the FD to /dev/null, -# effectively closing config.log, so it can be properly (re)opened and -# appended to by config.status. When coming back to configure, we -# need to make the FD available again. -if test "$no_create" != yes; then - ac_cs_success=: - ac_config_status_args= - test "$silent" = yes && - ac_config_status_args="$ac_config_status_args --quiet" - exec 5>/dev/null - $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false - exec 5>>config.log - # Use ||, not &&, to avoid exiting from the if with $? = 1, which - # would make configure fail if this is the last instruction. - $ac_cs_success || as_fn_exit 1 -fi -if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then - { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 -printf "%s\n" "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} -fi - - diff --git a/src/modules/rlm_couchbase/configure.ac b/src/modules/rlm_couchbase/configure.ac deleted file mode 100644 index 19ceff2d56..0000000000 --- a/src/modules/rlm_couchbase/configure.ac +++ /dev/null @@ -1,96 +0,0 @@ -AC_PREREQ([2.71]) -AC_INIT -AC_CONFIG_SRCDIR([rlm_couchbase.c]) -AC_REVISION($Revision$) -FR_INIT_MODULE([rlm_couchbase], [couchbase database support]) - -FR_MODULE_START_TESTS - -AC_PROG_CC -AC_PROG_CPP - -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=.]) - 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=.]) - FR_MODULE_FAIL([libcouchbase]) -fi - -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 diff --git a/src/modules/rlm_couchbase/couchbase.c b/src/modules/rlm_couchbase/couchbase.c deleted file mode 100644 index f8ce8bc28a..0000000000 --- a/src/modules/rlm_couchbase/couchbase.c +++ /dev/null @@ -1,421 +0,0 @@ -/* - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -/** - * $Id$ - * - * @brief Wrapper functions around the libcouchbase Couchbase client driver. - * @file couchbase.c - * - * @author Aaron Hurt (ahurt@anbcs.com) - * @copyright 2013-2014 The FreeRADIUS Server Project. - */ -RCSID("$Id$") - -#define LOG_PREFIX "couchbase" - -#include -#include - -#include "couchbase.h" - -/** Couchbase callback for cluster statistics requests - * - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @param error Couchbase error object. - * @param resp Couchbase statistics response object. - */ -void couchbase_stat_callback(lcb_t instance, const void *cookie, lcb_error_t error, const lcb_server_stat_resp_t *resp) -{ - if (error != LCB_SUCCESS) { - /* log error */ - ERROR("(stats_callback) %s (0x%x)", lcb_strerror(instance, error), error); - } - /* silent compiler */ - (void)cookie; - (void)resp; -} - -/** Couchbase callback for store (write) operations - * - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @param operation Couchbase storage operation object. - * @param error Couchbase error object. - * @param resp Couchbase store operation response object. - */ -void couchbase_store_callback(lcb_t instance, const void *cookie, lcb_storage_t operation, - lcb_error_t error, const lcb_store_resp_t *resp) -{ - if (error != LCB_SUCCESS) { - /* log error */ - ERROR("(store_callback) %s (0x%x)", lcb_strerror(instance, error), error); - } - /* silent compiler */ - (void)cookie; - (void)operation; - (void)resp; -} - -/** Couchbase callback for get (read) operations - * - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @param error Couchbase error object. - * @param resp Couchbase get operation response object. - */ -void couchbase_get_callback(lcb_t instance, const void *cookie, lcb_error_t error, const lcb_get_resp_t *resp) -{ - cookie_u cu; /* union of const and non const pointers */ - cu.cdata = cookie; /* set const union member to cookie passed from couchbase */ - cookie_t *c = (cookie_t *) cu.data; /* set our cookie struct using non-const member */ - const char *bytes = resp->v.v0.bytes; /* the payload of this chunk */ - lcb_size_t nbytes = resp->v.v0.nbytes; /* length of this data chunk */ - - /* check error */ - switch (error) { - case LCB_SUCCESS: - /* check for valid bytes */ - if (bytes && nbytes > 1) { - /* debug */ - DEBUG("(get_callback) got %zu bytes", nbytes); - /* parse string to json object */ - c->jobj = json_tokener_parse_ex(c->jtok, bytes, nbytes); - /* switch on tokener error */ - switch ((c->jerr = json_tokener_get_error(c->jtok))) { - case json_tokener_continue: - /* check object - should be null */ - if (c->jobj != NULL) { - ERROR("(get_callback) object not null on continue!"); - } - break; - case json_tokener_success: - /* do nothing */ - break; - default: - /* log error */ - ERROR("(get_callback) json parsing error: %s", - json_tokener_error_desc(c->jerr)); - break; - } - } - break; - - case LCB_KEY_ENOENT: - /* ignored */ - DEBUG("(get_callback) key does not exist"); - break; - - default: - /* log error */ - ERROR("(get_callback) %s (0x%x)", lcb_strerror(instance, error), error); - break; - } -} - -/** Couchbase callback for http (view) operations - * - * @param request Couchbase http request object. - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @param error Couchbase error object. - * @param resp Couchbase http response object. - */ -void couchbase_http_data_callback(lcb_http_request_t request, lcb_t instance, const void *cookie, - lcb_error_t error, const lcb_http_resp_t *resp) -{ - cookie_u cu; /* union of const and non const pointers */ - cu.cdata = cookie; /* set const union member to cookie passed from couchbase */ - cookie_t *c = (cookie_t *) cu.data; /* set our cookie struct using non-const member */ - const char *bytes = resp->v.v0.bytes; /* the payload of this chunk */ - lcb_size_t nbytes = resp->v.v0.nbytes; /* length of this data chunk */ - - /* check error */ - switch (error) { - case LCB_SUCCESS: - /* check for valid bytes */ - if (bytes && nbytes > 1) { - /* debug */ - DEBUG("(http_data_callback) got %zu bytes", nbytes); - /* parse string to json object */ - c->jobj = json_tokener_parse_ex(c->jtok, bytes, nbytes); - /* switch on tokener error */ - switch ((c->jerr = json_tokener_get_error(c->jtok))) { - case json_tokener_continue: - /* check object - should be null */ - if (c->jobj != NULL) ERROR("(http_data_callback) object not null on continue!"); - break; - case json_tokener_success: - /* do nothing */ - break; - default: - /* log error */ - ERROR("(http_data_callback) json parsing error: %s", json_tokener_error_desc(c->jerr)); - break; - } - } - break; - - default: - /* log error */ - ERROR("(http_data_callback) %s (0x%x)", lcb_strerror(instance, error), error); - break; - } - /* silent compiler */ - (void)request; -} - -/** Initialize a Couchbase connection instance - * - * Initialize all information relating to a Couchbase instance and configure available method callbacks. - * This function forces synchronous operation and will wait for a connection or timeout. - * - * @param instance Empty (un-allocated) Couchbase instance object. - * @param host The Couchbase server or list of servers. - * @param bucket The Couchbase bucket to associate with the instance. - * @param user The Couchbase bucket user (NULL if none). - * @param pass The Couchbase bucket password (NULL if none). - * @param timeout Maximum time to wait for obtaining the initial configuration. - * @param opts Extra options to configure the libcouchbase. - * @return Couchbase error object. - */ -lcb_error_t couchbase_init_connection(lcb_t *instance, const char *host, const char *bucket, const char *user, const char *pass, - lcb_uint32_t timeout, const couchbase_opts_t *opts) -{ - lcb_error_t error; /* couchbase command return */ - struct lcb_create_st options; /* init create struct */ - - /* init options */ - memset(&options, 0, sizeof(options)); - - /* assign couchbase create options */ - options.v.v0.host = host; - options.v.v0.bucket = bucket; - options.v.v0.user = user; - options.v.v0.passwd = pass; - - /* create couchbase connection instance */ - error = lcb_create(instance, &options); - if (error != LCB_SUCCESS) return error; - - error = lcb_cntl(*instance, LCB_CNTL_SET, LCB_CNTL_CONFIGURATION_TIMEOUT, &timeout); - if (error != LCB_SUCCESS) return error; - - /* Couchbase extra api settings */ - if (opts != NULL) { - const couchbase_opts_t *o = opts; - - for (; o != NULL; o = o->next) { - error = lcb_cntl_string(*instance, o->key, o->val); - if (error != LCB_SUCCESS) { - ERROR("Failed to configure the couchbase with %s=%s", o->key, o->val); - return error; - } - } - } - - /* initiate connection */ - error = lcb_connect(*instance); - if (error != LCB_SUCCESS) return error; - - /* set general method callbacks */ - lcb_set_stat_callback(*instance, couchbase_stat_callback); - lcb_set_store_callback(*instance, couchbase_store_callback); - lcb_set_get_callback(*instance, couchbase_get_callback); - lcb_set_http_data_callback(*instance, couchbase_http_data_callback); - /* wait on connection */ - lcb_wait(*instance); - - return LCB_SUCCESS; -} - -/** Request Couchbase server statistics - * - * Setup and execute a request for cluster statistics and wait for the result. - * - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @return Couchbase error object. - */ -lcb_error_t couchbase_server_stats(lcb_t instance, const void *cookie) -{ - lcb_error_t error; /* couchbase command return */ - lcb_server_stats_cmd_t cmd; /* server stats command struct */ - const lcb_server_stats_cmd_t *commands[1]; /* server stats commands array */ - - /* init commands */ - commands[0] = &cmd; - memset(&cmd, 0, sizeof(cmd)); - - /* populate command struct */ - cmd.v.v0.name = "tap"; - cmd.v.v0.nname = strlen(cmd.v.v0.name); - - /* get statistics */ - if ((error = lcb_server_stats(instance, cookie, 1, commands)) == LCB_SUCCESS) { - /* enter event look on success */ - lcb_wait(instance); - } - - /* return error */ - return error; -} - -/** Store a document by key in Couchbase - * - * Setup and execute a Couchbase set operation and wait for the result. - * - * @param instance Couchbase connection instance. - * @param key Document key to store in the database. - * @param document Document body to store in the database. - * @param expire Expiration time for the document (0 = never) - * @return Couchbase error object. - */ -lcb_error_t couchbase_set_key(lcb_t instance, const char *key, const char *document, int expire) -{ - lcb_error_t error; /* couchbase command return */ - lcb_store_cmd_t cmd; /* store command struct */ - const lcb_store_cmd_t *commands[1]; /* store commands array */ - - /* init commands */ - commands[0] = &cmd; - memset(&cmd, 0, sizeof(cmd)); - - /* populate command struct */ - cmd.v.v0.key = key; - cmd.v.v0.nkey = strlen(cmd.v.v0.key); - cmd.v.v0.bytes = document; - cmd.v.v0.nbytes = strlen(cmd.v.v0.bytes); - cmd.v.v0.exptime = expire; - cmd.v.v0.operation = LCB_SET; - - /* store key/document in couchbase */ - if ((error = lcb_store(instance, NULL, 1, commands)) == LCB_SUCCESS) { - /* enter event loop on success */ - lcb_wait(instance); - } - - /* return error */ - return error; -} - -/** Retrieve a document by key from Couchbase - * - * Setup and execute a Couchbase get request and wait for the result. - * - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @param key Document key to fetch. - * @return Couchbase error object. - */ -lcb_error_t couchbase_get_key(lcb_t instance, const void *cookie, const char *key) -{ - cookie_u cu; /* union of const and non const pointers */ - cu.cdata = cookie; /* set const union member to cookie passed from couchbase */ - cookie_t *c = (cookie_t *) cu.data; /* set our cookie struct using non-const member */ - lcb_error_t error; /* couchbase command return */ - lcb_get_cmd_t cmd; /* get command struct */ - const lcb_get_cmd_t *commands[1]; /* get commands array */ - - /* init commands */ - commands[0] = &cmd; - memset(&cmd, 0, sizeof(cmd)); - - /* populate command struct */ - cmd.v.v0.key = key; - cmd.v.v0.nkey = strlen(cmd.v.v0.key); - - /* clear cookie */ - memset(c, 0, sizeof(cookie_t)); - - /* init tokener error */ - c->jerr = json_tokener_success; - - /* create token */ - c->jtok = json_tokener_new(); - - /* debugging */ - DEBUG3("fetching document %s", key); - - /* get document */ - if ((error = lcb_get(instance, c, 1, commands)) == LCB_SUCCESS) { - /* enter event loop on success */ - lcb_wait(instance); - } - - /* free token */ - json_tokener_free(c->jtok); - - /* return error */ - return error; -} - -/** Query a Couchbase design document view - * - * Setup and execute a Couchbase view request and wait for the result. - * - * @param instance Couchbase connection instance. - * @param cookie Couchbase cookie for returning information from callbacks. - * @param path The fully qualified view path including the design document and view name. - * @param post The post payload (NULL for none). - * @return Couchbase error object. - */ -lcb_error_t couchbase_query_view(lcb_t instance, const void *cookie, const char *path, const char *post) -{ - cookie_u cu; /* union of const and non const pointers */ - cu.cdata = cookie; /* set const union member to cookie passed from couchbase */ - cookie_t *c = (cookie_t *) cu.data; /* set our cookie struct using non-const member */ - lcb_error_t error; /* couchbase command return */ - lcb_http_cmd_t cmd; /* http command struct */ - const lcb_http_cmd_t *commands; /* http commands array */ - - commands = &cmd; - memset(&cmd, 0, sizeof(cmd)); - - /* populate command struct */ - cmd.v.v0.path = path; - cmd.v.v0.npath = strlen(cmd.v.v0.path); - cmd.v.v0.body = post; - cmd.v.v0.nbody = post ? strlen(post) : 0; - cmd.v.v0.method = post ? LCB_HTTP_METHOD_POST : LCB_HTTP_METHOD_GET; - cmd.v.v0.chunked = 1; - cmd.v.v0.content_type = "application/json"; - - /* clear cookie */ - memset(c, 0, sizeof(cookie_t)); - - /* init tokener error */ - c->jerr = json_tokener_success; - - /* create token */ - c->jtok = json_tokener_new(); - - /* debugging */ - DEBUG3("fetching view %s", path); - - /* query the view */ - if ((error = lcb_make_http_request(instance, c, LCB_HTTP_TYPE_VIEW, commands, NULL)) == LCB_SUCCESS) { - /* enter event loop on success */ - lcb_wait(instance); - } - - /* free token */ - json_tokener_free(c->jtok); - - /* return error */ - return error; -} diff --git a/src/modules/rlm_couchbase/couchbase.h b/src/modules/rlm_couchbase/couchbase.h deleted file mode 100644 index 0aabb447e0..0000000000 --- a/src/modules/rlm_couchbase/couchbase.h +++ /dev/null @@ -1,107 +0,0 @@ -#pragma once -/* - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -/** - * $Id$ - * - * @brief Couchbase wrapper function prototypes and datatypes. - * @file couchbase.h - * - * @author Aaron Hurt (ahurt@anbcs.com) - * @copyright 2013-2014 The FreeRADIUS Server Project. - */ -RCSIDH(couchbase_h, "$Id$") - -#ifdef HAVE_WDOCUMENTATION -DIAG_OFF(documentation) -#endif -#include -#ifdef HAVE_WDOCUMENTATION -DIAG_ON(documentation) -#endif - -#include - -/** Information relating to the parsing of Couchbase document payloads - * - * This structure holds various references to json-c objects used when parsing - * Couchbase document payloads. - */ -typedef struct { - json_object *jobj; //!< JSON objects handled by the json-c library. - json_tokener *jtok; //!< JSON tokener objects handled by the json-c library. - enum json_tokener_error jerr; //!< Error values produced by the json-c library. -} cookie_t; - -/** Union of constant and non-constant pointers - * - * This is used to squelch compiler warnings about casting when passing data - * between functions expecting different data types. - */ -typedef union cookie_u { - const void *cdata; //!< Constant pointer to cookie payload (@p cookie_t). - void *data; //!< Non-constant pointer to data payload (@p cookie_t). -} cookie_u; - -/** - * This may be used to provide a simple interface from a command line or higher - * evel language to allow the setting of specific key-value pairs. - * - * Options ref: https://docs.couchbase.com/sdk-api/couchbase-c-client-2.5.6/group__lcb-cntl.html - */ -typedef struct couchbase_opts_s couchbase_opts_t; -struct couchbase_opts_s { - char *key; //!< Key value for lcb_cntl_string(). - char *val; //!< Value for the key used in lcb_cntl_string(). - couchbase_opts_t *next; //!< Linked list. -}; - -extern HIDDEN fr_dict_attr_t const *attr_acct_status_type; -extern HIDDEN fr_dict_attr_t const *attr_acct_session_time; -extern HIDDEN fr_dict_attr_t const *attr_event_timestamp; - -/* couchbase statistics callback */ -void couchbase_stat_callback(lcb_t instance, const void *cookie, lcb_error_t error, - const lcb_server_stat_resp_t *resp); - -/* store a key/document in couchbase */ -void couchbase_store_callback(lcb_t instance, const void *cookie, lcb_storage_t operation, - lcb_error_t error, const lcb_store_resp_t *item); - -/* get a document by key from couchbase */ -void couchbase_get_callback(lcb_t instance, const void *cookie, lcb_error_t error, - const lcb_get_resp_t *item); - -/* couchbase http callback for data chunks */ -void couchbase_http_data_callback(lcb_http_request_t request, lcb_t instance, - const void *cookie, lcb_error_t error, const lcb_http_resp_t *resp); - -/* create a couchbase instance and connect to the cluster */ -lcb_error_t couchbase_init_connection(lcb_t *instance, const char *host, const char *bucket, const char *user, - const char *pass, lcb_uint32_t timeout, const couchbase_opts_t *opts); - -/* get server statistics */ -lcb_error_t couchbase_server_stats(lcb_t instance, const void *cookie); - -/* store document/key in couchbase */ -lcb_error_t couchbase_set_key(lcb_t instance, const char *key, const char *document, int expire); - -/* pull document from couchbase by key */ -lcb_error_t couchbase_get_key(lcb_t instance, const void *cookie, const char *key); - -/* query a couchbase view via http */ -lcb_error_t couchbase_query_view(lcb_t instance, const void *cookie, const char *path, const char *post); diff --git a/src/modules/rlm_couchbase/mod.c b/src/modules/rlm_couchbase/mod.c deleted file mode 100644 index 35f236aab2..0000000000 --- a/src/modules/rlm_couchbase/mod.c +++ /dev/null @@ -1,923 +0,0 @@ -/* - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -/** - * $Id$ - * - * @brief Utility functions used in the module. - * @file mod.c - * - * @author Aaron Hurt (ahurt@anbcs.com) - * @copyright 2013-2014 The FreeRADIUS Server Project. - */ -RCSID("$Id$") - -#define LOG_PREFIX "couchbase" - -#include -#include -#include - -#include "mod.h" -#include "couchbase.h" - -/** Delete a connection pool handle and free related resources - * - * Destroys the underlying Couchbase connection handle freeing any related - * resources and closes the socket connection. - * - * @param chandle The connection handle to destroy. - * @return 0. - */ -static int _mod_conn_free(rlm_couchbase_handle_t *chandle) -{ - lcb_t cb_inst = chandle->handle; /* couchbase instance */ - - /* destroy/free couchbase instance */ - lcb_destroy(cb_inst); - - /* return */ - return 0; -} - -/** Delete a object built by mod_build_api_opts() - * - * Release the underlying mod_build_api_opts() objects - * - * @param inst The module instance. - * @return 0. - */ -int mod_free_api_opts(rlm_couchbase_t *inst) -{ - couchbase_opts_t *opts = inst->api_opts; - - if (!opts) return 0; - - DEBUG("Releasing the couchbase api options"); - - for (; opts != NULL; opts = opts->next) { - TALLOC_FREE(opts->key); - TALLOC_FREE(opts->val); - } - - TALLOC_FREE(opts); - - /* return */ - return 0; -} - -/** Build a couchbase_opts_t structure from the configuration "couchbase_api" list - * - * Parse the "couchbase_api" list from the module configuration file and store this - * as a couchbase_opts_t object (key/value list). - * - * @param conf Configuration list. - * @param inst The module instance. - * @return - * - 0 on success. - * - -1 on failure. - */ -int mod_build_api_opts(CONF_SECTION *conf, rlm_couchbase_t *inst) -{ - CONF_SECTION *cs; /* module config list */ - CONF_ITEM *ci; /* config item */ - CONF_PAIR *cp; /* config pair */ - couchbase_opts_t *entry = NULL; /* couchbase api options */ - - /* find opts list */ - cs = cf_section_find(conf, "opts", NULL); - - /* check list */ - if (!cs) return 0; - - /* parse libcouchbase_opts list */ - cf_log_debug(cs, "opts {"); - - for (ci = cf_item_next(cs, NULL); ci != NULL; ci = cf_item_next(cs, ci)) { - /* - * Ignore things we don't care about. - */ - if (!cf_item_is_pair(ci)) { - continue; - } - - /* get value pair from item */ - cp = cf_item_to_pair(ci); - - /* create opts object */ - if (!entry) { - entry = talloc_zero(inst, couchbase_opts_t); - inst->api_opts = entry; - } else { - entry->next = talloc_zero(inst->api_opts, couchbase_opts_t); - entry = entry->next; - } - entry->next = NULL; - entry->key = talloc_typed_strdup(entry, cf_pair_attr(cp)); - entry->val = talloc_typed_strdup(entry, cf_pair_value(cp)); - - /* debugging */ - cf_log_debug(cs, "\t%s = \"%s\"", entry->key, entry->val); - } - - cf_log_debug(cs, "}"); - - /* return */ - return 0; -} - -/** Create a new connection pool handle - * - * Create a new connection to Couchbase within the pool and initialize - * information associated with the connection instance. - * - * @param ctx The connection parent context. - * @param instance The module instance. - * @param timeout Maximum time to establish the connection. - * @return - * - New connection handle. - * - NULL on error. - */ -void *mod_conn_create(TALLOC_CTX *ctx, void *instance, fr_time_delta_t timeout) -{ - rlm_couchbase_t *inst = talloc_get_type_abort(instance, rlm_couchbase_t); /* module instance pointer */ - rlm_couchbase_handle_t *chandle = NULL; /* connection handle pointer */ - cookie_t *cookie = NULL; /* couchbase cookie */ - lcb_t cb_inst; /* couchbase connection instance */ - lcb_error_t cb_error; /* couchbase error status */ - couchbase_opts_t const *opts = inst->api_opts; /* couchbase extra API settings */ - - /* create instance */ - cb_error = couchbase_init_connection(&cb_inst, inst->server, inst->bucket, inst->username, - inst->password, fr_time_delta_to_sec(timeout), opts); - - /* check couchbase instance */ - if (cb_error != LCB_SUCCESS) { - ERROR("failed to initiate couchbase connection: %s (0x%x)", - lcb_strerror(NULL, cb_error), cb_error); - /* destroy/free couchbase instance */ - lcb_destroy(cb_inst); - /* fail */ - return NULL; - } - - /* allocate memory for couchbase connection instance abstraction */ - chandle = talloc_zero(ctx, rlm_couchbase_handle_t); - talloc_set_destructor(chandle, _mod_conn_free); - - /* allocate cookie off handle */ - cookie = talloc_zero(chandle, cookie_t); - - /* init tokener error and json object */ - cookie->jerr = json_tokener_success; - cookie->jobj = NULL; - - /* populate handle */ - chandle->cookie = cookie; - chandle->handle = cb_inst; - - /* return handle struct */ - return chandle; -} - -/** Check the health of a connection handle - * - * Attempt to determine the state of the Couchbase connection by requesting - * a cluster statistics report. Mark the connection as failed if the request - * returns anything other than success. - * - * @param opaque The module instance (currently unused). - * @param connection The connection handle. - * @return - * - 0 on success (alive). - * - -1 on failure (unavailable). - */ -int mod_conn_alive(UNUSED void *opaque, void *connection) -{ - rlm_couchbase_handle_t *chandle = connection; /* connection handle pointer */ - lcb_t cb_inst = chandle->handle; /* couchbase instance */ - lcb_error_t cb_error = LCB_SUCCESS; /* couchbase error status */ - - /* attempt to get server stats */ - if ((cb_error = couchbase_server_stats(cb_inst, NULL)) != LCB_SUCCESS) { - /* log error */ - ERROR("failed to get couchbase server stats: %s (0x%x)", - lcb_strerror(NULL, cb_error), cb_error); - /* error out */ - return -1; - } - return 0; -} - -/** Build a JSON object map from the configuration "map" list - * - * Parse the "map" list from the module configuration file and store this - * as a JSON object (key/value list) in the module instance. This map will be - * used to lookup and map attributes for all incoming accounting requests. - * - * @param conf Configuration list. - * @param inst The module instance. - * @return - * - 0 on success. - * - -1 on failure. - */ -int mod_build_attribute_element_map(CONF_SECTION *conf, rlm_couchbase_t *inst) -{ - CONF_SECTION *cs; /* module config list */ - CONF_ITEM *ci; /* config item */ - CONF_PAIR *cp; /* config pair */ - const char *attribute, *element; /* attribute and element names */ - - /* find update list */ - cs = cf_section_find(conf, "update", NULL); - - /* backwards compatibility */ - if (!cs) { - cs = cf_section_find(conf, "map", NULL); - WARN("found deprecated 'map' list - please change to 'update'"); - } - - /* check list */ - if (!cs) { - ERROR("failed to find 'update' list in config"); - /* fail */ - return -1; - } - - /* create attribute map object */ - inst->map = json_object_new_object(); - - /* parse update list */ - for (ci = cf_item_next(cs, NULL); ci != NULL; ci = cf_item_next(cs, ci)) { - /* validate item */ - if (!cf_item_is_pair(ci)) { - ERROR("failed to parse invalid item in 'update' list"); - /* free map */ - if (inst->map) { - json_object_put(inst->map); - } - /* fail */ - return -1; - } - - /* get value pair from item */ - cp = cf_item_to_pair(ci); - - /* get pair name (attribute name) */ - attribute = cf_pair_attr(cp); - - /* get pair value (element name) */ - element = cf_pair_value(cp); - - /* add pair name and value */ - json_object_object_add(inst->map, attribute, json_object_new_string(element)); - - /* debugging */ - DEBUG3("added attribute '%s' to element '%s' mapping", attribute, element); - } - - /* debugging */ - DEBUG3("built attribute to element mapping %s", json_object_to_json_string(inst->map)); - - /* return */ - return 0; -} - -/** Map attributes to JSON element names - * - * Attempt to map the passed attribute name to the configured JSON element - * name using the JSON object map mod_build_attribute_element_map(). - * - * @param name The character name of the requested attribute. - * @param map The JSON object map to use for the lookup. - * @param buf The buffer where the given element will be stored if found. - * @return - * - 0 on success. - * - -1 on failure. - */ -int mod_attribute_to_element(const char *name, json_object *map, void *buf) -{ - json_object *j_value; /* json object values */ - - /* clear buffer */ - memset((char *) buf, 0, MAX_KEY_SIZE); - - /* attempt to map attribute */ - if (json_object_object_get_ex(map, name, &j_value)) { - /* copy and check size */ - if (strlcpy(buf, json_object_get_string(j_value), MAX_KEY_SIZE) >= MAX_KEY_SIZE) { - /* oops ... this value is bigger than our buffer ... error out */ - ERROR("json map value larger than MAX_KEY_SIZE - %d", MAX_KEY_SIZE); - /* return fail */ - return -1; - } - /* looks good */ - return 0; - } - - /* debugging */ - DEBUG("skipping attribute with no map entry - %s", name); - - /* default return */ - return -1; -} - -/** Build value pairs from the passed JSON object and add to the request - * - * Parse the passed JSON object and create value pairs that will be injected into - * the given request for authorization. - * - * Example JSON document structure: - * @code{.json} - * { - * "docType": "raduser", - * "userName": "test", - * "control": { - * "SHA-Password": { - * "value": "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3", - * "op": ":=" - * } - * }, - * "reply": { - * "Reply-Message": { - * "value": "Hidey Ho!", - * "op": "=" - * } - * } - * } - * @endcode - * - * @param[in] ctx to allocate maps in. - * @param[in] out Cursor to append maps to. - * @param[in] request The request to which the generated pairs should be added. - * @param[in] json The JSON object representation of the user document. - * @param[in] list The pair list fr_request_attr_control or fr_request_attr_reply - * @return - * - 1 if no section found. - * - 0 on success. - * - <0 on error. - */ -int mod_json_object_to_map(TALLOC_CTX *ctx, fr_dcursor_t *out, request_t *request, json_object *json, fr_dict_attr_t const *list) -{ - json_object *list_obj; - char const *list_name = list->name; - - /* - * Check for a section matching the specified list - */ - if (!json_object_object_get_ex(json, list_name, &list_obj)) { - RDEBUG2("Couldn't find \"%s\" key in json object - Not adding value pairs for this attribute list", - list_name); - - return 1; - } - - /* - * Check the key representing the list is a JSON object - */ - if (!json_object_is_type(list_obj, json_type_object)) { - RERROR("Invalid json type for \"%s\" key - Attribute lists must be json objects", list_name); - - return -1; - } - - fr_dcursor_tail(out); /* Wind to the end */ - - /* - * Loop through the keys in this object. - * - * Where attr_name is the key, and attr_value_obj is - * the object containing the attributes value and - * operator. - */ - json_object_object_foreach(list_obj, attr_name, attr_value_obj) { - json_object *value_obj, *op_obj; - fr_dict_attr_t const *da; - fr_token_t op; - - if (!json_object_is_type(attr_value_obj, json_type_object)) { - REDEBUG("Invalid json type for \"%s\" key - Attributes must be json objects", attr_name); - - error: - fr_dcursor_free_list(out); /* Free any maps we added */ - return -1; - } - - RDEBUG3("Parsing %s - \"%s\" : { %s }", list_name, - attr_name, json_object_to_json_string(attr_value_obj)); - - /* - * Check we have a value key - */ - if (!json_object_object_get_ex(attr_value_obj, "value", &value_obj)) { - REDEBUG("Missing \"value\" key in: %s - \"%s\" : { %s }", list_name, - attr_name, json_object_to_json_string(attr_value_obj)); - - goto error; - } - - /* - * Parse the operator and check its valid - */ - if (json_object_object_get_ex(attr_value_obj, "op", &op_obj)) { - char const *op_str; - - op_str = json_object_get_string(op_obj); - if (!op_str) { - bad_op: - REDEBUG("Invalid \"op\" key in: %s - \"%s\" : { %s }", list_name, - attr_name, json_object_to_json_string(attr_value_obj)); - - goto error; - } - - op = fr_table_value_by_str(fr_tokens_table, op_str, T_INVALID); - if (!fr_assignment_op[op] && !fr_comparison_op[op]) goto bad_op; - } else { - op = T_OP_SET; /* The default */ - } - - /* - * Lookup the string attr_name in the - * request dictionary. - */ - da = fr_dict_attr_by_name(NULL, fr_dict_root(request->dict), attr_name); - if (!da) { - RPERROR("Invalid attribute \"%s\"", attr_name); - goto error; - } - - /* - * Create a map representing the operation - */ - { - fr_value_box_t tmp = { .type = FR_TYPE_NULL }; - map_t *map; - - if (fr_json_object_to_value_box(ctx, &tmp, value_obj, da, true) < 0) { - bad_value: - RPERROR("Failed parsing value for \"%s\"", attr_name); - goto error; - } - - if (fr_value_box_cast_in_place(ctx, &tmp, da->type, da) < 0) { - fr_value_box_clear(&tmp); - goto bad_value; - } - - if (map_afrom_value_box(ctx, &map, - attr_name, T_BARE_WORD, - &(tmpl_rules_t){ - .attr = { - .dict_def = request->dict, - .list_def = list - } - }, - op, - &tmp, true) < 0) { - fr_value_box_clear(&tmp); - goto bad_value; - } - - fr_dcursor_insert(out, map); - } - } - - return 0; -} - -/** Convert value pairs to json objects - * - * Take the passed value pair and convert it to a json-c JSON object.. - * - * @param request The request object. - * @param vp The value pair to convert. - * @return A JSON object. - */ -json_object *mod_value_pair_to_json_object(request_t *request, fr_pair_t *vp) -{ - char value[255]; /* radius attribute value */ - - /* add this attribute/value pair to our json output */ - { - unsigned int i; - - switch (vp->vp_type) { - case FR_TYPE_UINT32: - i = vp->vp_uint32; - goto print_int; - - case FR_TYPE_UINT16: - i = vp->vp_uint16; - goto print_int; - - case FR_TYPE_UINT8: - i = vp->vp_uint8; - - print_int: - /* skip if we have flags */ - if (vp->da->flags.has_value) break; -#ifdef HAVE_JSON_OBJECT_NEW_INT64 - /* debug */ - RDEBUG3("creating new int64 for unsigned 32 bit int/byte/short '%s'", vp->da->name); - /* return as 64 bit int - JSON spec does not support unsigned ints */ - return json_object_new_int64(i); -#else - /* debug */ - RDEBUG3("creating new int for unsigned 32 bit int/byte/short '%s'", vp->da->name); - /* return as 64 bit int - JSON spec does not support unsigned ints */ - return json_object_new_int(i); -#endif - - case FR_TYPE_INT32: -#ifdef HAVE_JSON_OBJECT_NEW_INT64 - /* debug */ - RDEBUG3("creating new int64 for signed 32 bit integer '%s'", vp->da->name); - /* return as 64 bit int - json-c represents all ints as 64 bits internally */ - return json_object_new_int64(vp->vp_int32); -#else - RDEBUG3("creating new int for signed 32 bit integer '%s'", vp->da->name); - /* return as signed int */ - return json_object_new_int(vp->vp_int32); -#endif - - case FR_TYPE_UINT64: -#ifdef HAVE_JSON_OBJECT_NEW_INT64 - /* debug */ - RDEBUG3("creating new int64 for 64 bit integer '%s'", vp->da->name); - /* return as 64 bit int - because it is a 64 bit int */ - return json_object_new_int64(vp->vp_uint64); -#else - /* warning */ - RWARN("skipping 64 bit integer attribute '%s' - please upgrade json-c to 0.10+", vp->da->name); - break; -#endif - - default: - /* silence warnings - do nothing */ - break; - } - } - - /* keep going if not set above */ - switch (vp->vp_type) { - case FR_TYPE_STRING: - /* debug */ - RDEBUG3("assigning string '%s' as string", vp->da->name); - /* return string value */ - return json_object_new_string(vp->vp_strvalue); - - default: - /* debug */ - RDEBUG3("assigning unhandled '%s' as string", vp->da->name); - /* get standard value */ - fr_pair_print_value_quoted(&FR_SBUFF_OUT(value, sizeof(value)), vp, T_BARE_WORD); - /* return string value from above */ - return json_object_new_string(value); - } -} - -/** Ensure accounting documents always contain a valid timestamp - * - * Inspect the given JSON object representation of an accounting document - * fetched from Couchbase and ensuse it contains a valid (non NULL) timestamp value. - * - * @param json JSON object representation of an accounting document. - * @param vps The value pairs associated with the current accounting request. - * @return - * - 0 on success. - * - -1 on failure. - */ -int mod_ensure_start_timestamp(json_object *json, fr_pair_list_t *vps) -{ - json_object *j_value; /* json object value */ - struct tm tm; /* struct to hold event time */ - time_t ts = 0; /* values to hold time in seconds */ - fr_pair_t *vp; /* values to hold value pairs */ - char value[255]; /* store radius attribute values and our timestamp */ - - /* get our current start timestamp from our json body */ - if (json_object_object_get_ex(json, "startTimestamp", &j_value) == 0) { - /* debugging ... this shouldn't ever happen */ - DEBUG("failed to find 'startTimestamp' in current json body"); - /* return */ - return -1; - } - - /* check for null value */ - if (json_object_get_string(j_value) != NULL) { - /* already set - nothing left to do */ - return 0; - } - - /* get current event timestamp */ - if ((vp = fr_pair_find_by_da(vps, NULL, attr_event_timestamp)) != NULL) { - /* get seconds value from attribute */ - ts = fr_unix_time_to_sec(vp->vp_date); - } else { - /* debugging */ - DEBUG("failed to find event timestamp in current request"); - /* return */ - return -1; - } - - /* clear value */ - memset(value, 0, sizeof(value)); - - /* get elapsed session time */ - if ((vp = fr_pair_find_by_da(vps, NULL, attr_acct_session_time)) != NULL) { - /* calculate diff */ - ts = (ts - vp->vp_uint32); - /* calculate start time */ - size_t length = strftime(value, sizeof(value), "%b %e %Y %H:%M:%S %Z", localtime_r(&ts, &tm)); - /* check length */ - if (length > 0) { - /* debugging */ - DEBUG("calculated start timestamp: %s", value); - /* store new value in json body */ - json_object_object_add_ex(json, "startTimestamp", json_object_new_string(value), - JSON_C_OBJECT_KEY_IS_CONSTANT); - } else { - /* debugging */ - DEBUG("failed to format calculated timestamp"); - /* return */ - return -1; - } - } - - /* default return */ - return 0; -} - -/** Handle client value processing for client_map_section() - * - * @param out Character output - * @param cp Configuration pair - * @param data The client data - * @return - * - 0 on success. - * - -1 on failure. - */ -static int _get_client_value(char **out, CONF_PAIR const *cp, void *data) -{ - json_object *j_value; - - if (!json_object_object_get_ex((json_object *)data, cf_pair_value(cp), &j_value)) { - *out = NULL; - return 0; - } - - if (!j_value) return -1; - - *out = talloc_strdup(NULL, json_object_get_string(j_value)); - if (!*out) return -1; - - return 0; -} - -/** Load client entries from Couchbase client documents on startup - * - * This function executes the view defined in the module configuration and loops - * through all returned rows. The view is called with "stale=false" to ensure the - * most accurate data available when the view is called. This will force an index - * rebuild on this design document in Couchbase. However, since this function is only - * run once at server startup this should not be a concern. - * - * @param inst The module instance. - * @param tmpl Default values for new clients. - * @param map The client attribute configuration list. - * @return - * - 0 on success. - * - -1 on failure. - */ -int mod_load_client_documents(rlm_couchbase_t *inst, CONF_SECTION *tmpl, CONF_SECTION *map) -{ - rlm_couchbase_handle_t *handle = NULL; /* connection pool handle */ - char vpath[256], vid[MAX_KEY_SIZE], vkey[MAX_KEY_SIZE]; /* view path and fields */ - char error[512]; /* view error return */ - int idx = 0; /* row array index counter */ - int retval = 0; /* return value */ - lcb_error_t cb_error = LCB_SUCCESS; /* couchbase error holder */ - json_object *json, *j_value; /* json object holders */ - json_object *jrows = NULL; /* json object to hold view rows */ - CONF_SECTION *client; /* freeradius config list */ - fr_client_t *c; /* freeradius client */ - - /* get handle */ - handle = fr_pool_connection_get(inst->pool, NULL); - - /* check handle */ - if (!handle) return -1; - - /* set couchbase instance */ - lcb_t cb_inst = handle->handle; - - /* set cookie */ - cookie_t *cookie = handle->cookie; - - /* build view path */ - snprintf(vpath, sizeof(vpath), "%s?stale=false", inst->client_view); - - /* query view for document */ - cb_error = couchbase_query_view(cb_inst, cookie, vpath, NULL); - - /* check error and object */ - if (cb_error != LCB_SUCCESS || cookie->jerr != json_tokener_success || !cookie->jobj) { - /* log error */ - ERROR("failed to execute view request or parse return"); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* debugging */ - DEBUG3("cookie->jobj == %s", json_object_to_json_string(cookie->jobj)); - - /* check for error in json object */ - if (json_object_object_get_ex(cookie->jobj, "error", &json)) { - /* build initial error buffer */ - strlcpy(error, json_object_get_string(json), sizeof(error)); - /* get error reason */ - if (json_object_object_get_ex(cookie->jobj, "reason", &json)) { - /* append divider */ - strlcat(error, " - ", sizeof(error)); - /* append reason */ - strlcat(error, json_object_get_string(json), sizeof(error)); - } - /* log error */ - ERROR("view request failed with error: %s", error); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* check for document id in return */ - if (!json_object_object_get_ex(cookie->jobj, "rows", &json)) { - /* log error */ - ERROR("failed to fetch rows from view payload"); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* get and hold rows */ - jrows = json_object_get(json); - - /* free cookie object */ - if (cookie->jobj) { - json_object_put(cookie->jobj); - cookie->jobj = NULL; - } - - /* debugging */ - DEBUG3("jrows == %s", json_object_to_json_string(jrows)); - - /* check for valid row value */ - if (!json_object_is_type(jrows, json_type_array) || json_object_array_length(jrows) < 1) { - /* log error */ - ERROR("no valid rows returned from view: %s", vpath); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* loop across all row elements */ - for (idx = 0; (size_t)idx < (size_t)json_object_array_length(jrows); idx++) { - /* fetch current index */ - json = json_object_array_get_idx(jrows, idx); - - /* get view id */ - if (json_object_object_get_ex(json, "id", &j_value)) { - /* clear view id */ - memset(vid, 0, sizeof(vid)); - /* copy and check length */ - if (strlcpy(vid, json_object_get_string(j_value), sizeof(vid)) >= sizeof(vid)) { - ERROR("id from row longer than MAX_KEY_SIZE (%d)", - MAX_KEY_SIZE); - continue; - } - } else { - WARN("failed to fetch id from row - skipping"); - continue; - } - - /* get view key */ - if (json_object_object_get_ex(json, "key", &j_value)) { - /* clear view key */ - memset(vkey, 0, sizeof(vkey)); - /* copy and check length */ - if (strlcpy(vkey, json_object_get_string(j_value), sizeof(vkey)) >= sizeof(vkey)) { - ERROR("key from row longer than MAX_KEY_SIZE (%d)", - MAX_KEY_SIZE); - continue; - } - } else { - WARN("failed to fetch key from row - skipping"); - continue; - } - - /* fetch document */ - cb_error = couchbase_get_key(cb_inst, cookie, vid); - - /* check error and object */ - if (cb_error != LCB_SUCCESS || cookie->jerr != json_tokener_success || !cookie->jobj) { - /* log error */ - ERROR("failed to execute get request or parse return"); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* debugging */ - DEBUG3("cookie->jobj == %s", json_object_to_json_string(cookie->jobj)); - - /* allocate conf list */ - client = tmpl ? cf_section_dup(NULL, NULL, tmpl, "client", vkey, true) : - cf_section_alloc(NULL, NULL, "client", vkey); - - if (client_map_section(client, map, _get_client_value, cookie->jobj) < 0) { - /* free config section */ - talloc_free(client); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* - * @todo These should be parented from something. - */ - c = client_afrom_cs(NULL, client, false, 0); - if (!c) { - ERROR("failed to allocate client"); - /* free config section */ - talloc_free(client); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* - * Client parents the CONF_SECTION which defined it. - */ - talloc_steal(c, client); - - /* attempt to add client */ - if (!client_add(NULL, c)) { - ERROR("failed to add client '%s' from '%s', possible duplicate?", vkey, vid); - /* free client */ - client_free(c); - /* set return */ - retval = -1; - /* return */ - goto free_and_return; - } - - /* debugging */ - DEBUG("client '%s' added", c->longname); - - /* free json object */ - if (cookie->jobj) { - json_object_put(cookie->jobj); - cookie->jobj = NULL; - } - } - - free_and_return: - - /* free rows */ - if (jrows) { - json_object_put(jrows); - } - - /* free json object */ - if (cookie->jobj) { - json_object_put(cookie->jobj); - cookie->jobj = NULL; - } - - /* release handle */ - if (handle) fr_pool_connection_release(inst->pool, NULL, handle); - - /* return */ - return retval; -} diff --git a/src/modules/rlm_couchbase/mod.h b/src/modules/rlm_couchbase/mod.h deleted file mode 100644 index 72fb139c55..0000000000 --- a/src/modules/rlm_couchbase/mod.h +++ /dev/null @@ -1,98 +0,0 @@ -#pragma once -/* - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -/** - * $Id$ - * - * @brief Function prototypes and datatypes used in the module. - * @file mod.h - * - * @author Aaron Hurt (ahurt@anbcs.com) - * @copyright 2013-2014 The FreeRADIUS Server Project. - */ -RCSIDH(mod_h, "$Id$") - -#include -#include - -#include - -/* maximum size of a stored value */ -#define MAX_VALUE_SIZE 20480 - -/* maximum length of a document key */ -#define MAX_KEY_SIZE 250 - -/** The main module instance - * - * This struct contains the core module configuration. - */ -typedef struct { - tmpl_t *acct_key; //!< Accounting document key. - char const *doctype; //!< Value of accounting 'docType' element name. - uint32_t expire; //!< Accounting document expire time in seconds. - - char const *server_raw; //!< Raw server string before parsing. - char const *server; //!< Couchbase server list. - char const *bucket; //!< Couchbase bucket. - char const *username; //!< Couchbase bucket username. - char const *password; //!< Couchbase bucket password. - - tmpl_t *user_key; //!< User document key. - - bool read_clients; //!< Toggle for loading client records. - const char *client_view; //!< Couchbase view that returns client documents. - - json_object *map; //!< Json object to hold user defined attribute map. - fr_pool_t *pool; //!< Connection pool. - char const *name; //!< Module instance name. - void *api_opts; //!< Couchbase API internal options. -} rlm_couchbase_t; - -/** Couchbase instance specific information - * - * This struct contains the Couchbase connection handle as well as a - * cookie pointer to store fetched document payloads. - */ -typedef struct { - void *handle; //!< Real couchbase instance. - void *cookie; //!< Couchbase cookie (@p cookie_u @p cookie_t). -} rlm_couchbase_handle_t; - -/* define functions */ -void *mod_conn_create(TALLOC_CTX *ctx, UNUSED void *instance, fr_time_delta_t timeout); - -int mod_conn_alive(void *opaque, void *connection); - -int mod_build_attribute_element_map(CONF_SECTION *conf, rlm_couchbase_t *inst); - -int mod_attribute_to_element(const char *name, json_object *map, void *buf); - -int mod_json_object_to_map(TALLOC_CTX *ctx, fr_dcursor_t *out, request_t *request, json_object *json, tmpl_pair_list_t list); - -json_object *mod_value_pair_to_json_object(request_t *request, fr_pair_t *vp); - -int mod_ensure_start_timestamp(json_object *json, fr_pair_list_t *vps); - -int mod_client_map_section(CONF_SECTION *client, CONF_SECTION const *map, json_object *json, char const *docid); - -int mod_load_client_documents(rlm_couchbase_t *inst, CONF_SECTION *tmpl, CONF_SECTION *map); - -int mod_build_api_opts(CONF_SECTION *conf, rlm_couchbase_t *inst); - -int mod_free_api_opts(rlm_couchbase_t *inst); - diff --git a/src/modules/rlm_couchbase/rlm_couchbase.c b/src/modules/rlm_couchbase/rlm_couchbase.c deleted file mode 100644 index f9f8ed9a98..0000000000 --- a/src/modules/rlm_couchbase/rlm_couchbase.c +++ /dev/null @@ -1,565 +0,0 @@ -/* - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -/** - * $Id$ - * - * @brief Integrate FreeRADIUS with the Couchbase document database. - * @file rlm_couchbase.c - * - * @author Aaron Hurt (ahurt@anbcs.com) - * @copyright 2013-2014 The FreeRADIUS Server Project. - */ - -RCSID("$Id$") - -#define LOG_PREFIX "couchbase - " - -#include -#include -#include -#include - -#include - -#include "mod.h" -#include "couchbase.h" - -/** - * Client Configuration - */ -static const conf_parser_t client_config[] = { - { FR_CONF_OFFSET("view", rlm_couchbase_t, client_view), .dflt = "_design/client/_view/by_name" }, - CONF_PARSER_TERMINATOR -}; - -/** - * Module Configuration - */ -static const conf_parser_t module_config[] = { - { FR_CONF_OFFSET_FLAGS("server", CONF_FLAG_REQUIRED, rlm_couchbase_t, server_raw) }, - { FR_CONF_OFFSET_FLAGS("bucket", CONF_FLAG_REQUIRED, rlm_couchbase_t, bucket) }, - { FR_CONF_OFFSET("username", rlm_couchbase_t, username) }, - { FR_CONF_OFFSET("password", rlm_couchbase_t, password) }, - - { FR_CONF_OFFSET("acct_key", rlm_couchbase_t, acct_key), .dflt = "radacct_%{%{Acct-Unique-Session-Id} || %{Acct-Session-Id}}", .quote = T_DOUBLE_QUOTED_STRING }, - { FR_CONF_OFFSET("doctype", rlm_couchbase_t, doctype), .dflt = "radacct" }, - { FR_CONF_OFFSET("expire", rlm_couchbase_t, expire), .dflt = 0 }, - - { FR_CONF_OFFSET("user_key", rlm_couchbase_t, user_key), .dflt = "raduser_%md5(%tolower(%{Stripped-User-Name} || %{User-Name}))", .quote = T_DOUBLE_QUOTED_STRING }, - { FR_CONF_OFFSET("read_clients", rlm_couchbase_t, read_clients) }, /* NULL defaults to "no" */ - { FR_CONF_POINTER("client", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) client_config }, - CONF_PARSER_TERMINATOR -}; - -static fr_dict_t const *dict_radius; - -extern fr_dict_autoload_t rlm_couchbase_dict[]; -fr_dict_autoload_t rlm_couchbase_dict[] = { - { .out = &dict_radius, .proto = "radius" }, - { NULL } -}; - -fr_dict_attr_t const *attr_acct_status_type; -fr_dict_attr_t const *attr_acct_session_time; -fr_dict_attr_t const *attr_event_timestamp; - -extern fr_dict_attr_autoload_t rlm_couchbase_dict_attr[]; -fr_dict_attr_autoload_t rlm_couchbase_dict_attr[] = { - { .out = &attr_acct_status_type, .name = "Acct-Status-Type", .type = FR_TYPE_UINT32, .dict = &dict_radius }, - { .out = &attr_acct_session_time, .name = "Acct-Session-Time", .type = FR_TYPE_UINT32, .dict = &dict_radius }, - { .out = &attr_event_timestamp, .name = "Event-Timestamp", .type = FR_TYPE_DATE, .dict = &dict_radius }, - { NULL } -}; - -/** Handle authorization requests using Couchbase document data - * - * Attempt to fetch the document associated with the requested user by - * using the deterministic key defined in the configuration. When a valid - * document is found it will be parsed and the containing value pairs will be - * injected into the request. - * - * @param[out] p_result Operation status (#rlm_rcode_t). - * @param[in] mctx module calling context. - * @param[in] request The authorization request. - */ -static unlang_action_t mod_authorize(rlm_rcode_t *p_result, module_ctx_t const *mctx, request_t *request) -{ - rlm_couchbase_t const *inst = talloc_get_type_abort_const(mctx->mi->data, rlm_couchbase_t); /* our module instance */ - rlm_couchbase_handle_t *handle = NULL; /* connection pool handle */ - char buffer[MAX_KEY_SIZE]; - char const *dockey; /* our document key */ - lcb_error_t cb_error = LCB_SUCCESS; /* couchbase error holder */ - rlm_rcode_t rcode = RLM_MODULE_OK; /* return code */ - ssize_t slen; - - /* assert packet as not null */ - fr_assert(request->packet != NULL); - - /* attempt to build document key */ - slen = tmpl_expand(&dockey, buffer, sizeof(buffer), request, inst->user_key, NULL, NULL); - if (slen < 0) RETURN_MODULE_FAIL; - if ((dockey == buffer) && is_truncated((size_t)slen, sizeof(buffer))) { - REDEBUG("Key too long, expected < " STRINGIFY(sizeof(buffer)) " bytes, got %zi bytes", slen); - RETURN_MODULE_FAIL; - } - - /* get handle */ - handle = fr_pool_connection_get(inst->pool, request); - - /* check handle */ - if (!handle) RETURN_MODULE_FAIL; - - /* set couchbase instance */ - lcb_t cb_inst = handle->handle; - - /* set cookie */ - cookie_t *cookie = handle->cookie; - - /* fetch document */ - cb_error = couchbase_get_key(cb_inst, cookie, dockey); - - /* check error */ - if (cb_error != LCB_SUCCESS || !cookie->jobj) { - /* log error */ - RERROR("failed to fetch document or parse return"); - /* set return */ - rcode = RLM_MODULE_FAIL; - /* return */ - goto finish; - } - - /* debugging */ - RDEBUG3("parsed user document == %s", json_object_to_json_string(cookie->jobj)); - - { - TALLOC_CTX *pool = talloc_pool(request, 1024); /* We need to do lots of allocs */ - fr_dcursor_t maps; - map_t *map = NULL; - fr_dlist_head_t map_head; - vp_list_mod_t *vlm; - fr_dlist_head_t vlm_head; - - fr_dcursor_init(&maps, &map_head); - - /* - * Convert JSON data into maps - */ - if ((mod_json_object_to_map(pool, &maps, request, cookie->jobj, request_attr_control) < 0) || - (mod_json_object_to_map(pool, &maps, request, cookie->jobj, request_attr_reply) < 0) || - (mod_json_object_to_map(pool, &maps, request, cookie->jobj, request_attr_request) < 0) || - (mod_json_object_to_map(pool, &maps, request, cookie->jobj, request_attr_state) < 0)) { - invalid: - talloc_free(pool); - rcode = RLM_MODULE_INVALID; - goto finish; - } - - fr_dlist_init(&vlm_head, vp_list_mod_t, entry); - - /* - * Convert all the maps into list modifications, - * which are guaranteed to succeed. - */ - while ((map = fr_dlist_next(&map_head, map))) { - if (map_to_list_mod(pool, &vlm, request, map, NULL, NULL) < 0) goto invalid; - fr_dlist_insert_tail(&vlm_head, vlm); - } - - if (fr_dlist_empty(&vlm_head)) { - RDEBUG2("Nothing to update"); - talloc_free(pool); - rcode = RLM_MODULE_NOOP; - goto finish; - } - - /* - * Apply the list of modifications - */ - while ((vlm = fr_dlist_next(&vlm_head, vlm))) { - int ret; - - ret = map_list_mod_apply(request, vlm); /* SHOULD NOT FAIL */ - if (!fr_cond_assert(ret == 0)) { - talloc_free(pool); - rcode = RLM_MODULE_FAIL; - goto finish; - } - } - - talloc_free(pool); - } - -finish: - /* free json object */ - if (cookie->jobj) { - json_object_put(cookie->jobj); - cookie->jobj = NULL; - } - - /* release handle */ - if (handle) fr_pool_connection_release(inst->pool, request, handle); - - /* return */ - RETURN_MODULE_RCODE(rcode); -} - -/** Write accounting data to Couchbase documents - * - * Handle accounting requests and store the associated data into JSON documents - * in couchbase mapping attribute names to JSON element names per the module configuration. - * - * When an existing document already exists for the same accounting section the new attributes - * will be merged with the currently existing data. When conflicts arrise the new attribute - * value will replace or be added to the existing value. - * - * @param[out] p_result Result of calling the module. - * @param mctx module calling context. - * @param request The accounting request object. - */ -static unlang_action_t mod_accounting(rlm_rcode_t *p_result, module_ctx_t const *mctx, request_t *request) -{ - rlm_couchbase_t const *inst = talloc_get_type_abort_const(mctx->mi->data, rlm_couchbase_t); /* our module instance */ - rlm_couchbase_handle_t *handle = NULL; /* connection pool handle */ - rlm_rcode_t rcode = RLM_MODULE_OK; /* return code */ - fr_pair_t *vp; /* radius value pair linked list */ - char buffer[MAX_KEY_SIZE]; - char const *dockey; /* our document key */ - char document[MAX_VALUE_SIZE]; /* our document body */ - char element[MAX_KEY_SIZE]; /* mapped radius attribute to element name */ - int status = 0; /* account status type */ - int docfound = 0; /* document found toggle */ - lcb_error_t cb_error = LCB_SUCCESS; /* couchbase error holder */ - ssize_t slen; - - - /* assert packet as not null */ - fr_assert(request->packet != NULL); - - /* sanity check */ - if ((vp = fr_pair_find_by_da(&request->request_pairs, NULL, attr_acct_status_type)) == NULL) { - /* log debug */ - RDEBUG2("could not find status type in packet"); - /* return */ - RETURN_MODULE_NOOP; - } - - /* set status */ - status = vp->vp_uint32; - - /* acknowledge the request but take no action */ - if (status == FR_STATUS_ACCOUNTING_ON || status == FR_STATUS_ACCOUNTING_OFF) { - /* log debug */ - RDEBUG2("handling accounting on/off request without action"); - /* return */ - RETURN_MODULE_OK; - } - - /* get handle */ - handle = fr_pool_connection_get(inst->pool, request); - - /* check handle */ - if (!handle) RETURN_MODULE_FAIL; - - /* set couchbase instance */ - lcb_t cb_inst = handle->handle; - - /* set cookie */ - cookie_t *cookie = handle->cookie; - - /* attempt to build document key */ - slen = tmpl_expand(&dockey, buffer, sizeof(buffer), request, inst->acct_key, NULL, NULL); - if (slen < 0) { - rcode = RLM_MODULE_FAIL; - goto finish; - } - if ((dockey == buffer) && is_truncated((size_t)slen, sizeof(buffer))) { - REDEBUG("Key too long, expected < " STRINGIFY(sizeof(buffer)) " bytes, got %zi bytes", slen); - rcode = RLM_MODULE_FAIL; - /* return */ - goto finish; - } - - /* attempt to fetch document */ - cb_error = couchbase_get_key(cb_inst, cookie, dockey); - - /* check error and object */ - if (cb_error != LCB_SUCCESS || cookie->jerr != json_tokener_success || !cookie->jobj) { - /* log error */ - RERROR("failed to execute get request or parse returned json object"); - /* free and reset json object */ - if (cookie->jobj) { - json_object_put(cookie->jobj); - cookie->jobj = NULL; - } - /* check cookie json object */ - } else if (cookie->jobj) { - /* set doc found */ - docfound = 1; - /* debugging */ - RDEBUG3("parsed json body from couchbase: %s", json_object_to_json_string(cookie->jobj)); - } - - /* start json document if needed */ - if (docfound != 1) { - /* debugging */ - RDEBUG2("no existing document found - creating new json document"); - /* create new json object */ - cookie->jobj = json_object_new_object(); - /* set 'docType' element for new document */ - json_object_object_add_ex(cookie->jobj, "docType", json_object_new_string(inst->doctype), - JSON_C_OBJECT_KEY_IS_CONSTANT); - /* default startTimestamp and stopTimestamp to null values */ - json_object_object_add_ex(cookie->jobj, "startTimestamp", NULL, JSON_C_OBJECT_KEY_IS_CONSTANT); - json_object_object_add_ex(cookie->jobj, "stopTimestamp", NULL, JSON_C_OBJECT_KEY_IS_CONSTANT); - } - - /* status specific replacements for start/stop time */ - switch (status) { - case FR_STATUS_START: - /* add start time */ - if ((vp = fr_pair_find_by_da(&request->request_pairs, NULL, attr_acct_status_type)) != NULL) { - /* add to json object */ - json_object_object_add_ex(cookie->jobj, "startTimestamp", - mod_value_pair_to_json_object(request, vp), - JSON_C_OBJECT_KEY_IS_CONSTANT); - } - break; - - case FR_STATUS_STOP: - /* add stop time */ - if ((vp = fr_pair_find_by_da(&request->request_pairs, NULL, attr_event_timestamp)) != NULL) { - /* add to json object */ - json_object_object_add_ex(cookie->jobj, "stopTimestamp", - mod_value_pair_to_json_object(request, vp), - JSON_C_OBJECT_KEY_IS_CONSTANT); - } - /* check start timestamp and adjust if needed */ - mod_ensure_start_timestamp(cookie->jobj, &request->request_pairs); - break; - - case FR_STATUS_ALIVE: - /* check start timestamp and adjust if needed */ - mod_ensure_start_timestamp(cookie->jobj, &request->request_pairs); - break; - - default: - /* don't doing anything */ - rcode = RLM_MODULE_NOOP; - /* return */ - goto finish; - } - - /* loop through pairs and add to json document */ - for (vp = fr_pair_list_head(&request->request_pairs); - vp; - vp = fr_pair_list_next(&request->request_pairs, vp)) { - /* map attribute to element */ - if (mod_attribute_to_element(vp->da->name, inst->map, &element) == 0) { - /* debug */ - RDEBUG3("mapped attribute %s => %s", vp->da->name, element); - /* add to json object with mapped name */ - json_object_object_add(cookie->jobj, element, mod_value_pair_to_json_object(request, vp)); - } - } - - /* copy json string to document and check size */ - if (strlcpy(document, json_object_to_json_string(cookie->jobj), sizeof(document)) >= sizeof(document)) { - /* this isn't good */ - RERROR("could not write json document - insufficient buffer space"); - /* set return */ - rcode = RLM_MODULE_FAIL; - /* return */ - goto finish; - } - - /* debugging */ - RDEBUG3("setting '%s' => '%s'", dockey, document); - - /* store document/key in couchbase */ - cb_error = couchbase_set_key(cb_inst, dockey, document, inst->expire); - - /* check return */ - if (cb_error != LCB_SUCCESS) { - RERROR("failed to store document (%s): %s (0x%x)", dockey, lcb_strerror(NULL, cb_error), cb_error); - } - -finish: - /* free and reset json object */ - if (cookie->jobj) { - json_object_put(cookie->jobj); - cookie->jobj = NULL; - } - - /* release our connection handle */ - if (handle) { - fr_pool_connection_release(inst->pool, request, handle); - } - - /* return */ - RETURN_MODULE_RCODE(rcode); -} - - -/** Detach the module - * - * Detach the module instance and free any allocated resources. - * - * @param mctx The module instance. - * @return Returns 0 (success) in all conditions. - */ -static int mod_detach(module_detach_ctx_t const *mctx) -{ - rlm_couchbase_t *inst = talloc_get_type_abort(mctx->mi->data, rlm_couchbase_t); - - if (inst->map) json_object_put(inst->map); - if (inst->pool) fr_pool_free(inst->pool); - if (inst->api_opts) mod_free_api_opts(inst); - - return 0; -} - -/** Initialize the rlm_couchbase module - * - * Initialize the module and create the initial Couchbase connection pool. - * - * @param mctx The module instance. - * @return - * - 0 on success. - * - -1 on failure. - */ -static int mod_instantiate(module_inst_ctx_t const *mctx) -{ - rlm_couchbase_t *inst = talloc_get_type_abort(mctx->mi->data, rlm_couchbase_t); /* our module instance */ - CONF_SECTION *conf = mctx->mi->conf; - - { - char *server, *p; - size_t len, i; - bool sep = false; - - len = talloc_array_length(inst->server_raw) - 1; - server = p = talloc_array(inst, char, len + 1); - for (i = 0; i < len; i++) { - switch (inst->server_raw[i]) { - case '\t': - case ' ': - case ',': - /* Consume multiple separators occurring in sequence */ - if (sep == true) continue; - - sep = true; - *p++ = ';'; - break; - - default: - sep = false; - *p++ = inst->server_raw[i]; - break; - } - } - - *p = '\0'; - inst->server = server; - } - - /* setup item map */ - if (mod_build_attribute_element_map(conf, inst) != 0) { - /* fail */ - return -1; - } - - /* setup libcouchbase extra options */ - if (mod_build_api_opts(conf, inst) != 0) { - /* fail */ - return -1; - } - - /* initiate connection pool */ - inst->pool = module_rlm_connection_pool_init(conf, inst, mod_conn_create, mod_conn_alive, NULL, NULL, NULL); - - /* check connection pool */ - if (!inst->pool) { - ERROR("failed to initiate connection pool"); - /* fail */ - return -1; - } - - /* load clients if requested */ - if (inst->read_clients) { - CONF_SECTION *cs, *map, *tmpl; /* conf section */ - - /* attempt to find client section */ - cs = cf_section_find(conf, "client", NULL); - if (!cs) { - ERROR("failed to find client section while loading clients"); - /* fail */ - return -1; - } - - /* attempt to find attribute subsection */ - map = cf_section_find(cs, "attribute", NULL); - if (!map) { - ERROR("failed to find attribute subsection while loading clients"); - /* fail */ - return -1; - } - - tmpl = cf_section_find(cs, "template", NULL); - - /* debugging */ - DEBUG("preparing to load client documents"); - - /* attempt to load clients */ - if (mod_load_client_documents(inst, tmpl, map) != 0) { - /* fail */ - return -1; - } - } - - /* return okay */ - return 0; -} - -static int mod_load(void) -{ - INFO("libcouchbase version: %s", lcb_get_version(NULL)); - fr_json_version_print(); - return 0; -} - -/* - * Hook into the FreeRADIUS module system. - */ -extern module_rlm_t rlm_couchbase; -module_rlm_t rlm_couchbase = { - .common = { - .magic = MODULE_MAGIC_INIT, - .name = "couchbase", - .inst_size = sizeof(rlm_couchbase_t), - .config = module_config, - .onload = mod_load, - .instantiate = mod_instantiate, - .detach = mod_detach - }, - .method_group = { - .bindings = (module_method_binding_t[]){ - { .section = SECTION_NAME("accounting", CF_IDENT_ANY), .method = mod_accounting }, - { .section = SECTION_NAME("recv", CF_IDENT_ANY), .method = mod_authorize }, - MODULE_BINDING_TERMINATOR - } - } -}; -- 2.47.3