mirror of
https://github.com/netdata/netdata.git
synced 2025-04-14 01:29:11 +00:00

This PR adds the logs-management external plugin. See the included README for an extensive list of features. ------------------------------------------------------------------------------------- * Add proper status return in JSON response of functions * Add column info to functions * Escape special characters when returning JSON response * Add proper functions help and defaults. Fix help not working * Add 'logs_management_meta' object in functions results * Fix compiler warnings * Replace tabs with 3 spaces in web_client_api_request_v1_logsmanagement_sources() * Add 'sources' in functions to display list of log sources * Update functions column values for logs * Update chart titles and remove '/s' from units * Add support for compound queries in circular buffers * Refactor circ_buff_search() to get rid of circ_buff_search_compound() * Fix incorrect docker events nano timestamp padding * Fixed botched rebasing * Replace get_unix_time_ms() with now_realtime_msec() * Remove binary generation from Fluent-Bit lib build * Fix compiler warnings due to new timestamp type * Remove STDIN and STDOUT support from Fluent-Bit library * Initial support for FLB_KMSG kernel logs collection * Add kernel logs charts * Add kernel logs subsystem and device charts * Skip collection of pre-existing logs in kmsg ring buffer * Add example of custom kmsg charts * Add extra initialization error logs * Fix bug of Docker Events collector failure disabling whole logs management engine * Remove reduntant FLB output code * Remove some obsolete TODO comments * Remove some commented out error/debug prints * Disable some Fluent-Bit config options not required * Make circular buffer spare items option configurable * Add DB mode configuration option * Replace p_file_infos_arr->data[i] with p_file_info in db_api.c * Remove db_loop due to all function calls being synchronous * Add initial README.md * Add DB mode = none changes * Add a simple webpage to visualize log query results * Add support for source selection to logs_query.html * Add option to query multiple log sources * Mark non-queryable sources as such in logs_query.html * Add option to use either GET or functions request in logs_query.html * Install logs_query.html when running stress tests * Update README.md requirements * Change installer behavior to build logs management by default * Disable logs management at runtime by default * Add global db mode configuration in 'logs management' config section * Split logsmanagement.conf into required & optional sections * Remove --enable-logsmanagement from stress test script * Add global config option for 'circular buffer max size MiB' * Add global config option for 'circular buffer drop logs if full' * Update 'General Configuration' in README.md * Add global config option for remaining optional settings * Add systemd collector requirements to TOC * README: Convert general configuration to table * README: Fix previous botched commit * Enable logs management by default when building for stress testing * Move logging to collector.log from error.log * Fix contenttype compilation errors * Move logging to collector.log in plugin_logsmanagement.c * Rename 'rows' to 'records' in charts * Add Netdata error.log parsing * Add more dashboard descriptions * Sanitize chart ids * Attempt to fix failing CI * Update README.md * Update README.md * Another attempt to fix CI failures * Fix undefined reference to 'uv_sleep' on certain platforms * Support FLB forward input and FLB output plugins. Squashed commit of the following: commit 55e2bf4fb34a2e02ffd0b280790197310a5299f3 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Apr 13 16:41:09 2023 +0300 Remove error.log from stock config commit bbdc62c2c9727359bc3c8ef8c33ee734d0039be7 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Apr 13 16:37:48 2023 +0300 Add cleanup of Fluent Bit outputs in p_file_info_destroy() commit 09b0aa4268ec1ccef160c99c5d5f31b6388edd28 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Apr 13 14:34:17 2023 +0300 Some code and config cleanup commit 030d074667d5ee2cad10f85cd836ca90e29346ad Author: Dim-P <dimitris1703@gmail.com> Date: Thu Apr 13 13:04:08 2023 +0300 Enable additional Fluent Bit output plugins for shared library commit 490aa5d44caa38042521d24c6b886b8b4a59a73c Author: Dim-P <dimitris1703@gmail.com> Date: Thu Apr 13 01:33:19 2023 +0300 Add initialization of Fluent Bit user-configured outputs commit c96e9fe9cea96549aa5eae09d0deeb130da02793 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Apr 4 23:13:16 2023 +0100 Complete read of parameters for FLB outputs config commit 00988897f9b86d1ecc5c141b19df7ad7d74f7e96 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Apr 3 19:43:31 2023 +0100 Update README.md commit 6deea5399c2707942aeaa51408f999ca45dfd351 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Apr 3 16:02:28 2023 +0100 Refactor Syslog_parser_config_t and add Flb_socket_config_t commit 7bf998a4c298bbd489ef735c56a6e85a137772c9 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Apr 3 14:19:57 2023 +0100 Update README.md commit c353d194b12c54f134936072ebaded0424d73cc0 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Mar 31 14:52:57 2023 +0100 Update README.md commit 6be726eaff3738ba7884de799aa52949833af65a Author: Dim-P <dimitris1703@gmail.com> Date: Fri Mar 31 13:06:29 2023 +0100 Update README. Fix docker_events streaming commit 6aabfb0f1ef0529a7a0ecbaf940bc0952bf42518 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Mar 30 21:27:45 2023 +0100 Fix stuck in infinite loop bug for FLB_GENERIC, FLB_WEB_LOG and FLB_SERIAL remote log sources commit eea6346b708cc7a5ce6e2249366870f4924eabae Author: Dim-P <dimitris1703@gmail.com> Date: Thu Mar 30 21:04:12 2023 +0100 Remove callback that searches for streamed p_file_info match commit bc9c5a523b0b0ab5588adbff391a43ba8d9a0cdf Author: Dim-P <dimitris1703@gmail.com> Date: Thu Mar 30 15:51:39 2023 +0100 Basic streaming works commit 4c80f59f0214bc07895f0b2edca47cb02bc06420 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Mar 28 22:05:22 2023 +0100 WIP commit eeb37a71b602fb0738fe8077ccddc0a8ce632304 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Mar 27 22:52:09 2023 +0100 Add generic forward streaming input commit 1459b91847c80c4d97de96b75b00771039458ad6 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Mar 23 18:50:14 2023 +0000 FLB_FORWARD: WIP * Add number of logs per item in DB and in queries response * Fix wrong number of lines stored in DB for web logs * Refactor number of logs parsers and charts code * Add option to toggle number of collected logs metrics and charts * Disable kmsg log collector by default * Fix logs_query.html to work with any server ip * Fix regressed wrong number of web log lines bug * Change query quota type from size_t to long long * Update alpine version when searching for fts-dev requirements * Update query results to return both requested and actual quota * Fix bug of circ buffs not being read if head == read but not empty * Squashed commit of the following: commit 34edb316a737f3edcffcf8fa88a3801599011495 Author: Dim-P <dimitris1703@gmail.com> Date: Thu May 4 20:02:36 2023 +0100 Comment out some debug prints commit 51b9b87a88516186530f5b4b65f785b543fefe8c Author: Dim-P <dimitris1703@gmail.com> Date: Fri Apr 28 19:21:54 2023 +0100 Fix wrong filenames in BLOBS_TABLE after rotation commit 6055fc2893b48661af324f20ee61511a40abbc02 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Apr 28 12:22:04 2023 +0100 Add chart showing number of circular buffer items commit 0bb5210b0847f4b7596f633ec96fc10aa8ebc791 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Apr 25 16:47:29 2023 +0300 Various fixes. Fix num_lines calculation. Add debug prints for circ buffers. Remove circ buff spare items option. Fix calculation of circ buff memory consumption. Add buff_realloc_rwlock for db_mode = none case. Fix circ buff read to be done correctly when buff is full. commit f494af8c95be84404c7d854494d26da3bcbd3ad7 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Apr 21 16:03:50 2023 +0300 Fix freez() on non-malloced address commit cce6d09e9cf9b847aface7309643e2c0a6041390 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Apr 21 15:41:25 2023 +0300 Add option to dynamically expand circ buffs when full * Use log timestamps when possible, instead of collection timestamps. Also, add config options for Fluent Bit engine and remove tail_plugin. Squashed commit of the following: commit b16a02eb6e3a90565c90e0a274b87b123e7b18e5 Author: Dim-P <dimitris1703@gmail.com> Date: Tue May 16 19:38:57 2023 +0100 Add Fluent Bit service config options to netdata.conf. Add monitoring of new log file fluentbit.log commit ab77c286294548ea62a3879ac0f8b8bbfe6a0687 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 21:25:17 2023 +0100 Remove some debug prints commit 46d64ad2434e69b1d20720297aec1ddb869e1f84 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 21:19:32 2023 +0100 Fix null values in charts commit 8ec96821d6a882f28cbd19244ebdfc86c807d2f4 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 17:43:04 2023 +0100 Update README.md to reflect log timestamp changes commit 079a91858cf9db2f74711581235bc17eb97c7dad Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 16:23:14 2023 +0100 Add configurable option for 'update timeout' commit 72b5e2505d4657fcbb5ccb6eeee00c45eb0b51ff Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 16:05:08 2023 +0100 Revert logsmanagement.conf to logs-manag-master one commit 70d0ea6f8d272fff318aa3095d90a78dcc3411a7 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 16:02:00 2023 +0100 Fix bug of circ buff items not marked as done commit 5716420838771edb7842be4669bf96235b15cf71 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 15 16:01:41 2023 +0100 Fix do_custom_charts_update() to work for all log sources commit a8def8f53fd25c3efa56ef27e267df3261913a8e Author: Dim-P <dimitris1703@gmail.com> Date: Fri May 12 18:20:20 2023 +0100 Remove GENERIC and WEB_LOG cases. Remove tail_plugin.c/h. Remove generic_parser(). commit 1cf05966e33491dbeb9b877f18d1ea8643aabeba Author: Dim-P <dimitris1703@gmail.com> Date: Fri May 12 16:54:59 2023 +0100 Fix FLB_GENERIC and FLB_SERIAL to work with new timestamp logic commit df3266810531f1af5f99b666fbf44c503b304a39 Author: Dim-P <dimitris1703@gmail.com> Date: Fri May 12 14:55:04 2023 +0100 Get rid of *_collect() functions and restructure plugin_logsmanagement workers commit 3eee069842f3257fffe60dacfc274363bc43491c Author: Dim-P <dimitris1703@gmail.com> Date: Fri May 12 14:28:33 2023 +0100 Fix wrong order of #define _XOPEN_SOURCE 700 in parser.c commit 941aa80cb55d5a7d6fe8926da930d9803be52312 Author: Dim-P <dimitris1703@gmail.com> Date: Thu May 11 22:27:39 2023 +0100 Update plugin_logsmanagement_web_log to use new timestamp logic and to support delayed logs. Refactor req_method metrics code. commit 427a7d0e2366d43cb5eab7daa1ed82dfc3bc8bc8 Author: Dim-P <dimitris1703@gmail.com> Date: Tue May 9 20:26:08 2023 +0100 Update plugin_logsmanagement_kernel to use new timestamp logic and to support delayed charts commit a7e95a6d3e5c8b62531b671fd3ec7b8a3196b5bb Author: Dim-P <dimitris1703@gmail.com> Date: Tue May 9 15:22:14 2023 +0100 Update plugin_logsmanagement_systemd to use new timestamp logic and support delayed charts commit 48237ac2ce49c82abdf2783952fd9f0ef05d72e1 Author: Dim-P <dimitris1703@gmail.com> Date: Tue May 9 13:29:44 2023 +0100 Refactor number of collected logs chart update code commit a933c8fcae61c23fa0ec6d0074526ac5d243cf16 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 8 22:11:19 2023 +0100 Update plugin_logsmanagement_docker_ev to use new timestamp logic and support delayed charts commit 5d8db057155affd5cb721399a639d75a81801b7f Author: Dim-P <dimitris1703@gmail.com> Date: Fri May 5 15:18:06 2023 +0100 Change some Fluent Bit collectors to use log timestamps instead of collection timestamps * Remove some unused defines and typedefs * Improve flb_init() * Update file-level doxygen. Add SPDX license declaration. * Better handling of termination of Fluent Bit * Better handling of DB errors. Various fixes. Squashed commit of the following: commit f55feea1274c3857eda1e9d899743db6e3eb5bf5 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Jun 6 13:28:00 2023 +0100 Fix web log parsing in case of lines terminated by \r commit 9e05758a4ecfac57a0db14757cff9536deda51d8 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Jun 5 20:42:05 2023 +0100 Fix warnings due to -Wformat-truncation=2 commit 63477666fa42446d74693aae542580d4e1e81f03 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Jun 5 16:48:45 2023 +0100 Autodiscovery of Netdata error.log based on netdata_configured_log_dir commit cab5e6d6061f4259172bbf72666e8b4a3a35dd66 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Jun 5 16:24:39 2023 +0100 Replace Forward config default string literals with macros commit 4213398031dbb53afbc943d76bf7df202d12bf6f Author: Dim-P <dimitris1703@gmail.com> Date: Mon Jun 5 15:56:29 2023 +0100 Proper cleanup of flb_lib_out_cb *callback in case of error commit f76fd7cc7bc2d0241e4d3517f61ae192d4246300 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Jun 5 15:36:07 2023 +0100 Proper termination of Forward input and respective log sources in case of error commit 3739fd96c29e13298eb3a6e943a63172cdf39d5f Author: Dim-P <dimitris1703@gmail.com> Date: Thu Jun 1 21:19:56 2023 +0100 Merge db_search() and db_search_compound() commit fcface90cb0a6df3c3a2de5e1908b1b3467dd579 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Jun 1 19:17:26 2023 +0100 Proper error handling in db_search() and db_search_compound(). Refactor the code too. commit c10667ebee2510a1af77114b3a7e18a0054b5dae Author: Dim-P <dimitris1703@gmail.com> Date: Thu Jun 1 14:23:34 2023 +0100 Update DB mode and dir when switching to db_mode_none commit d37d4c3d79333bb9fa430650c13ad625458620e8 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Jun 1 12:56:13 2023 +0100 Fix flb_stop() SIGSEGV commit 892e231c68775ff1a1f052d292d26384f1ef54b1 Author: Dim-P <dimitris1703@gmail.com> Date: Tue May 30 21:14:58 2023 +0100 Switch to db_writer_db_mode_none if db_writer_db_mode_full encounters error commit f7a0c2135ff61d3a5b0460ec5964eb6bce164bd6 Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 29 21:41:21 2023 +0100 Complete error handling changes to db_init(). Add some const type qualifiers. Refactor some code for readability commit 13dbeac936d22958394cb1aaec394384f5a93fdd Author: Dim-P <dimitris1703@gmail.com> Date: Mon May 29 17:14:17 2023 +0100 More error handling changes in db_init(). Change some global default settings if stress testing. commit eb0691c269cd09054190bf0ee9c4e9247b4a2548 Author: Dim-P <dimitris1703@gmail.com> Date: Fri May 26 23:29:12 2023 +0100 Better handling of db writer threads errors. Add db timings charts * Fix mystrsep() replaced by strsep_skip_consecutive_separators() * Fix older GCC failure due to label before declaration * Fix failed builds when using libuv <= v1.19 * Fix some Codacy warnings * Fix warning: implicit declaration of function ‘strsep’ * Use USEC_PER_SEC instead of 1000000ULL * Use UUID_STR_LEN instead of GUID_LEN + 1 * Combine multiple 'ln -sf' Docker instructions to one * Update README with systemd development libraries requirement * Comment out mallocz() success checkes in parser_csv() * Fix shellcheck warnings * Remove asserts for empty SYSLOG_IDENTIFIER or PID * Fix FreeBSD failing builds * Fix some more shellcheck warnings * Update Alpine fts-dev required packages * First changes to use web log timestamp for correct metrics timings * Initial work to add test_parse_web_log_line() unit test * Complete test_parse_web_log_line() tests * Improve parse_web_log_line() for better handling of \n, \r, double quotes etc. * Fix 'Invalid TIME error when timezone sign is negative * Add more logs to compression unit test case * Misc read_last_line() improvements * Fix failing test_auto_detect_web_log_parser_config() when test case terminated without '\n' * Remove unused preprocessor macro * Factor out setup of parse_config_expected_num_fields * Add test for count_fields() * Add unit test for read_last_line() * Fix a read_last_line() bug * Remove PLUGIN[logsmanagement] static thread and update charts synchronously, right before data buffering * Fix web log parser potential SIGSEGV * Fix web log metrics bug where they could show delayed by 1 collection interval * WIP: Add multiline support to kmsg logs and fix metric timings * Fix kmsg subsystem and device parsing and metrics * Add option 'use log timestamp' to select between log timestamps or collection timestamps * Add 'Getting Started' docs section * Move logs management functions code to separate source files * Add 'Nginx access.log' chart description * Remove logsmanagement.plugin source files * Fix some memory leaks * Improve cleanup of logsmanagement_main() * Fix a potential memory leak of fwd_input_out_cb * Better termination and cleanup of main_loop and its handles * Fix main_db_dir access() check bug * Avoid uv_walk() SIGSEGV * Remove main_db_dir access() check * Better termination and cleanup of DB code * Remove flb_socket_config_destroy() that could cause a segmentation fault * Disable unique client IPs - all-time chart by default * Update README.md * Fix debug() -> netdata_log_debug() * Fix read_last_line() * Fix timestamp sign adjustment and wrong unit tests * Change WEB_CLIENT_ACL_DASHBOARD to WEB_CLIENT_ACL_DASHBOARD_ACLK_WEBRTC * Do not parse web log timestamps if 'use_log_timestamp = no' * Add Logs Management back into buildinfo.c * Update README.md * Do not build Fluent Bit executable binary * Change logs rate chart to RRDSET_TYPE_LINE * Add kludge to prevent metrics breaking due to out of order logs * Fix wrong flb_tmp_buff_cpy_timer expiration * Refactor initialization of input plugin for local log sources. * Rename FLB_GENERIC collector to FLB_TAIL. * Switch 'Netdata fluentbit.log' to disabled by default * Add 'use inotify' configuration option * Update in README.md * Add docker event actions metrics * Update README.md to include event action chart * Remove commented out PLUGIN[logsmanagement] code block * Fix some warnings * Add documentation for outgoing log streaming and exporting * Fix some code block formatting in README.md * Refactor code related to error status of log query results and add new invalid timestamp case * Reduce query mem allocs and fix end timestamp == 0 bug * Add support for duplicate timestamps in db_search() * Add support for duplicate timestamps in circ_buff_search() * Fix docker events contexts * Various query fixes prior to reverse order search. - Add reverse qsort() function in circ buffers. - Fix issues to properly support of duplicate timestamps. - Separate requested from actual timestamps in query parameters. - Rename results buffer variable name to be consistent between DB and buffers. - Remove default start and end timestamp from functions. - Improve handling of invalid quotas provided by users. - Rename 'until' timestamp name to 'to'. - Increase default quota to 10MB from 1MB. - Allow start timestamp to be > than end timestamp. * Complete descending timestamp search for circular buffers * Complete descending timestamp search for DB * Remove MEASURE_QUERY_TIME code block * Complete descending timestamp search when data resides in both DB and circular buffers * Use pointer instead of copying res_hdr in query results * Refactor web log timezone parsing to use static memory allocation * Add stats for CPU user & system time per MiB of query results * Micro-optimization to slightly speed up queries * More micro-optimizations and some code cleanup * Remove LOGS_QUERY_DATA_FORMAT_NEW_LINE option * Escape iscntrl() chars at collection rather at query * Reduce number of buffer_strcat() calls * Complete descending timestamp order queries for web_api_v1 * Complete descending timestamp order queries for functions * Fix functions query timings to match web_api_v1 ones * Add MQTT message collector Squashed commit of the following: commit dbe515372ee04880b1841ef7800abe9385b12e1c Author: Dim-P <dimitris1703@gmail.com> Date: Mon Aug 21 15:18:46 2023 +0100 Update README.md with MQTT information commit c0b5dbcb7cdef8c6fbd5e72e7bdd08957a0fd3de Author: Dim-P <dimitris1703@gmail.com> Date: Mon Aug 21 14:59:36 2023 +0100 Tidy up before merge commit 9a69c4f17eac858532918a8f850a770b12710f80 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Aug 21 12:54:33 2023 +0100 Fix issue with duplicate Log_Source_Path in DB, introduced in commit e417af3 commit 48213e9713216d62fca8a5bc1bbc41a3883fdc14 Author: Dim-P <dimitris1703@gmail.com> Date: Sat Aug 19 05:05:36 2023 +0100 WIP commit e417af3b947f11bd61e3255306bc95953863998d Author: Dim-P <dimitris1703@gmail.com> Date: Thu Aug 17 18:03:39 2023 +0100 Update functions logsmanagement help output * Inhibit Fluent Bit build warnings * Fix missing allow_subpaths value in api_commands_v1[]. * Fix missing HTTP_RESP_BACKEND_FETCH_FAILED error * Fix an enum print warning * Remove systemd-devel requirement from README and fix codacy warnings * Update Alpine versions for musl-fts-dev * Update Fluent Bit to v2.1.8 Squashed commit of the following: commit faf6fc4b7919cc2611124acc67cb1973ce705530 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Aug 25 17:13:30 2023 +0100 Fix wrong default CORE_STACK_SIZE on Alpine commit a810238fe7830ce626f6d57245d68035b29723f7 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Aug 25 00:40:02 2023 +0100 Update Fluent Bit patches for musl commit 8bed3b611dba94a053e22c2b4aa1d46f7787d9b4 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Aug 24 21:54:38 2023 +0100 Fix an edge case crash when web log method is '-' commit b29b48ea230363142697f9749508cd926e18ee19 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Aug 24 16:26:13 2023 +0100 Disable FLB_OUT_CALYPTIA to fix Alpine dlsym() error commit eabe0d0523ffe98ff881675c21b0763a49c05f16 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Aug 22 21:25:54 2023 +0100 Add 'use inotify = no' troubleshooting Q&A in README commit 7f7ae85bdb0def63b4fc05ab88f6572db948e0e7 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Aug 22 18:06:36 2023 +0100 Update README.md links to latest version commit 610c5ac7b920d4a1dfe364ad48f1ca14a0acc346 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Aug 22 16:23:30 2023 +0100 Update flb_parser_create() definition commit f99608ff524b6f3462264e626a1073f9c2fdfdf5 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Aug 22 16:23:04 2023 +0100 Add new config.cmake options commit 446b0d564626055a0a125f525d0bd3754184b830 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Aug 22 12:21:25 2023 +0100 Update Fluent Bit submodule to v2.1.8 * Add logs_management_unittest() to CI 'unittest' * Remove obsolete query testing files * Patch Fluent Bit log format to match netdata's format * Update README with instructions on how to monitor Podman events logs * Fix core dump in case of flb_lib_path dlopen() * Fix some potential compiler warnings * Fix queries crash if logs manag engine not running * Much faster termination of LOGS MANAGEMENT * Add facets support and other minor fixes. logsmanagement_function_execute_cb() is replaced by logsmanagement_function_facets() which adds facets support to logs management queries. Internal query results header now includes additional fields (log_source, log_type, basename, filename, chartname), that are used as facets. Queries now support timeout as a query parameter. A web log timestamp bug is fixed (by using timegm() instead of mktime(). web_api_v1 logsmanagement API is only available in debugging now. Squashed commit of the following: commit 32cf0381283029d793ec3af30d96e6cd77ee9149 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 19 16:21:32 2023 +0300 Tidy up commit f956b5846451c6b955a150b5d071947037e935f0 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 19 13:30:54 2023 +0300 Add more accepted params. Add data_only option. Add if_modified_since option. commit 588c2425c60dcdd14349b7b346467dba32fda4e9 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Sep 18 18:39:50 2023 +0300 Add timeout to queries commit da0f055fc47a36d9af4b7cc4cefb8eb6630e36d9 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 14 19:17:16 2023 +0300 Fix histogram commit 7149890974e0d26420ec1c5cfe1023801dc973fa Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 14 17:58:52 2023 +0300 Add keyword query using simple patterns and fix descending timestamp values commit 0bd068c5a76e694b876027e9fa5af6f333ab825b Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 14 13:54:05 2023 +0300 Add basename, filename, chartname as facets commit 023c2b5f758b2479a0e48da575cd59500a1373b6 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 14 13:26:06 2023 +0300 Add info and sources functions options commit ab4d555b7d445f7291af474847bd9177d3726a76 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 14 12:54:37 2023 +0300 Fix facet id filter commit a69c9e2732f5a6da1764bb57d1c06d8d65979225 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 14 12:07:13 2023 +0300 WIP: Add facet id filters commit 3c02b5de81fa8a20c712863c347539a52936ddd8 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 12 18:19:17 2023 +0300 Add log source and log type to circ buff query results header commit 8ca98672c4911c126e50f3cbdd69ac363abdb33d Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 12 18:18:13 2023 +0300 Fix logsmanagement facet function after master rebasing commit 3f1517ad56cda2473a279a8d130bec869fc2cbb8 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 12 18:14:25 2023 +0300 Restrict /logsmanagement to ACL_DEV_OPEN_ACCESS only commit 8ca98d69b08d006c682997268d5d2523ddde6be0 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 12 14:40:22 2023 +0300 Fix incorrectly parsed timestamps due to DST commit f9b0848037b29c7fcc46da951ca5cd9eb129066f Author: Dim-P <dimitris1703@gmail.com> Date: Mon Sep 11 13:42:18 2023 +0300 Add logs_management_meta object to facet query results commit babc978f6c97107aaf8b337d8d31735d61761b6a Author: Dim-P <dimitris1703@gmail.com> Date: Mon Sep 11 13:03:52 2023 +0300 Query all sources if no arguments provided commit 486d56de87af56aae6c0dc5d165341418222ce8b Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 7 18:38:04 2023 +0300 Add log_source and log_type (only for DB logs) as facets. Add relative time support commit b564c12843d355c4da6436af358d5f352cb58bfe Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 7 13:47:20 2023 +0300 Working facet with descending timestamps commit 68c6a5c64e8425cf28ec16adfb0c50289caa82a9 Author: Dim-P <dimitris1703@gmail.com> Date: Wed Sep 6 01:55:51 2023 +0300 WIP * Fix linking errors * Convert logs management to external plugin. Squashed commit of the following: commit 16da6ba70ebde0859aed734087f04af497ce3a77 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 18:44:12 2023 +0100 Use higher value of update every from netdata.conf or logsmanagement.d.conf commit 88cc3497c403e07686e9fc0876ebb0c610a1404c Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 18:43:02 2023 +0100 Tidy up commit c3fca57aac169842637d210269519612b1a91e28 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 18:02:04 2023 +0100 Use external update_every from agent, if available commit f7470708ba82495b03297cdf8962a09b16617ddd Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 17:40:46 2023 +0100 Re-enable debug logs commit b34f5ac6a2228361ab41df7d7e5e713f724368c0 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 15:49:20 2023 +0100 Remove old API calls from web_api_v1.c/h commit 7fbc1e699a7785ec837233b9562199ee6c7684da Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 15:32:04 2023 +0100 Add proper termination of stats charts thread commit 4c0fc05c8b14593bd7a0aa68f75a8a1205e04db4 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 24 15:31:36 2023 +0100 Add tests for logsmanag_config functions commit 4dfdacb55707ab46ed6c2d5ce538ac012574b27e Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 23 22:01:19 2023 +0100 Remove unused headers from logsmanagement.c commit b324ef396207c5c32e40ea9ad462bf374470b230 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 23 21:56:26 2023 +0100 Remove inline from get_X_dir() functions commit e9656e8121b66cd7ef8b5daaa5d27a134427aa35 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 23 21:50:32 2023 +0100 Proper termination when a signal is received commit b09eec147bdeffae7b268b6335f6ba89f084e050 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 23 20:12:13 2023 +0100 Refactor logs management config code in separate source files commit 014b46a5008fd296f7d25854079c518d018abdec Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 23 14:54:47 2023 +0100 Fix p_file_info_destroy() crash commit e0bdfd182513bb8d5d4b4b5b8a4cc248ccf2d64e Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 23 14:18:27 2023 +0100 Code refactoring and cleanup commit 6a61cb6e2fd3a535db150b01d9450f44b3e27b30 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Oct 20 14:08:43 2023 +0100 Fix 'source:all' queries commit 45b516aaf819ac142353e323209b7d01e487393f Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 19 21:51:05 2023 +0100 Working 'source:...' queries and regular data queries (but not 'source:all') commit 8064b0ee71c63da9803f79424802f860e96326e5 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 19 15:34:23 2023 +0100 Fix issue due to p_file_info_destroy() commit a0aacc9cd00cea60218c9bfd2b9f164918a1e3de Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 17 22:06:34 2023 +0100 Work on facet API changes commit 480584ff9040c07e996b14efb4d21970a347633f Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 16 21:43:06 2023 +0100 Add stats charts, running as separate thread commit 34d582dbe4bf2d8d048afab41681e337705bc611 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 16 16:24:02 2023 +0100 Add SSL cipher charts commit ced27ee4e2c981d291f498244f2eef2556a074fb Author: Dim-P <dimitris1703@gmail.com> Date: Sun Oct 15 21:33:29 2023 +0100 Add Response code family, Response code, Response code type, SSL protocol charts commit 40c4a1d91892d49b1e4e18a1c3c43258ded4014d Author: Dim-P <dimitris1703@gmail.com> Date: Sat Oct 14 00:48:48 2023 +0100 Add more web log charts commit 890ed3ff97153dd18d15df2d1b57a181bc498ca8 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Oct 13 22:14:11 2023 +0100 Add web log vhosts and ports charts commit 84733b6b1d353aff70687603019443610a8500c3 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 12 21:40:16 2023 +0100 Add systemd charts commit 14673501e8f48560956f53d5b670bbe801b8f2ae Author: Dim-P <dimitris1703@gmail.com> Date: Wed Oct 11 00:28:43 2023 +0100 Add MQTT charts commit 366eb63b0a27dde6f0f8ba65120f34c18c1b21fd Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 10 21:46:19 2023 +0100 Complete kmsg changes. Reduce mem usage. Fix a dictionary key size bug commit 3d0216365a526ffbc9ce13a20c45447bfccb47d9 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 10 19:18:41 2023 +0100 Add kmsg Subsystem charts commit e61af4bb130a5cf5a5a78133f1e44b2b4c457b24 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 10 16:21:29 2023 +0100 Fix bug of wrong kmsg timestamps in case of use_log_timestamp == 0 commit 03d22e0b26bddf249aab431a4f977bbd5cde98ca Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 10 16:20:47 2023 +0100 Add kmsg charts, except for Subsystem and Device commit f60b0787537a21ed3c4cea5101fcddc50f3bc55a Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 10 13:12:13 2023 +0100 Initialise all docker events chart dimensions at startup commit 5d873d3439abaf3768530cb5b72c6b4ef6565353 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 10 00:53:35 2023 +0100 WIP: Add Docker events logs commit 2cc3d6d98f58fc3ab67a8da3014210b14d0926a1 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 9 18:52:27 2023 +0100 Use macros for num_of_logs_charts and custom_charts functions commit fbd48ad3c9af674601238990d74192427475f2e3 Author: Dim-P <dimitris1703@gmail.com> Date: Mon Oct 9 18:26:17 2023 +0100 Refactor custom charts code for clarity and speed commit a31d80b5dc91161c0d74b10d00bc4fd1e6da7965 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 5 23:58:27 2023 +0100 Add first working iteration of custom charts commit b1e4ab8a460f4b4c3e2804e2f775787d21fbee45 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 5 23:57:27 2023 +0100 Add more custom charts for Netdata error.log commit f1b7605e564da3e297942f073593cdd4c21f88e1 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 5 20:39:40 2023 +0100 Convert collected_logs_* chart updates to macros commit 1459bc2b8bcd5ba21e024b10a8a5101048938f71 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Oct 5 19:11:54 2023 +0100 Use rrdset_timed_done() instead of duration_since_last_update for correct chart timings commit 876854c6ee7586a3eb9fdbf795bcc17a5fd1e6ad Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 3 21:53:14 2023 +0100 Fix some bugs in chart updates commit ae87508485499984bcb9b72bbc7d249c4168b380 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Oct 3 21:32:55 2023 +0100 Functioning generic_chart_init() and generic_chart_update() commit 982a9c4108dbea9571c785b5ff8a9d1e5472066c Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 28 23:32:52 2023 +0100 Add support for multiple .conf files. Add stock examples. commit 8e8abd0731227eb3fb3c6bcd811349575160799e Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 28 17:38:30 2023 +0100 Add support for logsmanagement.d/default.conf commit 1bf0732217b1d9e9959e1507ea96fc2c92ffb2ff Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 28 14:31:03 2023 +0100 Add capabilities. Fix paths in logsmanagement.d.conf commit a849d5b405bb4e5d770726fe99413a4efa7df274 Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 26 23:06:31 2023 +0100 Change logs_manag_config_load() commit b0d1783b996286cd87e0832bfb74c29a845d61fc Author: Dim-P <dimitris1703@gmail.com> Date: Tue Sep 26 15:35:30 2023 +0100 Working unit tests and argument parsing commit 6da1b4267a4d58d3a7cbcca9507afe8158a2e324 Author: Dim-P <dimitris1703@gmail.com> Date: Fri Sep 22 00:32:47 2023 +0300 Build logs-management.plugin successfully commit 9e30efe0422e4941f99cc66998d9f42e00a24676 Author: Dim-P <dimitris1703@gmail.com> Date: Thu Sep 21 16:13:21 2023 +0300 Fix print format specifier in web_client_api_request_v1_logsmanagement() * Modify CODEOWNERS * Update README.md Fix indentation * Change snprintfz() to stncpyz() in circ_buff_search(). Change remaining 'chart_name' to 'chartname'. * Replace SQLite version function with macro * Fix some codacy warnings * Update README.md * Update Fluent Bit to v2.1.10 * Remove some comments * Fix Fluent Bit shared library linking for armv7l and FreeBSD * Remove compression source files * Add prefix to rrd_api.h functions * Add more unit tests * Fix kmsg capabilities * Separate kmsg and systemd default paths * Fix some memory leaks and better termination of DB * Add iterative queries if quota is exceeded * Fix centos7 builds * Fix issue where SYSTEMD timestamps are not parsed * Fix logs management packaging. * Fix typo in DEB control file. * Fix indentation and missing new line at EOF * Clean up functions and update help * Fix 400 error when no queryable sources are available * Fix if_modified_since. Add FACET_MAX_VALUE_LENGTH * Add delta parameter and use anchor points in queries * Fix CodeQL #182 warning * Fix packaging issues. * Fix postinstall script for DEB packages. * Improve plugin shutdown speed * Fix docker events chart grouping * Fix functions evloop threads not terminating upon shutdown * Fix coverity issues * Fix logging * Replace 'Netdata error.log' with 'Netdata daemon.log' in 'default.conf' * Remove 'enabled = yes/no' config in logsmanagement.d.conf * Remove 'enabled = X' unused config from logsmanagement.d.conf --------- Co-authored-by: Austin S. Hemmelgarn <austin@netdata.cloud>
2269 lines
72 KiB
Text
2269 lines
72 KiB
Text
#
|
|
# Copyright (C) 2015 Alon Bar-Lev <alon.barlev@gmail.com>
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
#
|
|
AC_PREREQ(2.60)
|
|
|
|
# We do not use m4_esyscmd_s to support older autoconf.
|
|
define([VERSION_STRING], m4_esyscmd([git describe 2>/dev/null | tr -d '\n']))
|
|
define([VERSION_FROM_FILE], m4_esyscmd([cat packaging/version | tr -d '\n']))
|
|
m4_ifval(VERSION_STRING, [], [define([VERSION_STRING], VERSION_FROM_FILE)])
|
|
|
|
AC_INIT([netdata], VERSION_STRING[])
|
|
|
|
AM_MAINTAINER_MODE([disable])
|
|
if test x"$USE_MAINTAINER_MODE" = xyes; then
|
|
AC_MSG_NOTICE(***************** MAINTAINER MODE *****************)
|
|
fi
|
|
|
|
PACKAGE_RPM_VERSION="VERSION_STRING"
|
|
AC_SUBST([PACKAGE_RPM_VERSION])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# autoconf initialization
|
|
|
|
AC_CONFIG_AUX_DIR([.])
|
|
AC_CONFIG_HEADERS([config.h])
|
|
AC_CONFIG_MACRO_DIR([build/m4])
|
|
AC_CONFIG_SRCDIR([daemon/main.c])
|
|
define([AUTOMATE_INIT_OPTIONS], [tar-pax subdir-objects])
|
|
m4_ifdef([AM_SILENT_RULES], [
|
|
define([AUTOMATE_INIT_OPTIONS], [tar-pax silent-rules subdir-objects])
|
|
])
|
|
AM_INIT_AUTOMAKE(AUTOMATE_INIT_OPTIONS)
|
|
m4_ifdef([AM_SILENT_RULES], [
|
|
AM_SILENT_RULES([yes])
|
|
])
|
|
AC_CANONICAL_HOST
|
|
AC_PROG_CC
|
|
AC_PROG_CC_C99
|
|
AM_PROG_CC_C_O
|
|
AC_PROG_CXX
|
|
AC_PROG_INSTALL
|
|
PKG_PROG_PKG_CONFIG
|
|
AC_USE_SYSTEM_EXTENSIONS
|
|
|
|
AC_LANG_PUSH([C])
|
|
AX_COMPILER_VENDOR
|
|
AC_LANG_POP([C])
|
|
if test "$ax_cv_c_compiler_vendor" = "clang"; then
|
|
AC_CHECK_PROG([AR], [llvm-ar], [llvm-ar], [ar])
|
|
AC_CHECK_PROG([RANLIB], [llvm-ranlib], [llvm-ranlib], [ranlib])
|
|
else
|
|
AC_CHECK_TOOL([RANLIB], [ranlib])
|
|
AC_CHECK_TOOL([AR], [ar])
|
|
fi
|
|
|
|
CFLAGS="$CFLAGS -fexceptions"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# configurable options
|
|
|
|
AC_ARG_ENABLE(
|
|
[plugin-nfacct],
|
|
[AS_HELP_STRING([--enable-plugin-nfacct], [enable nfacct plugin @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_plugin_nfacct="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[plugin-freeipmi],
|
|
[AS_HELP_STRING([--enable-plugin-freeipmi], [enable freeipmi plugin @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_plugin_freeipmi="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[plugin-systemd-journal],
|
|
[AS_HELP_STRING([--enable-plugin-systemd-journal], [enable systemd-journal plugin @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_plugin_systemd_journal="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[logsmanagement],
|
|
[AS_HELP_STRING([--disable-logsmanagement], [Disable logsmanagement @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_logsmanagement="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[logsmanagement_tests],
|
|
[AS_HELP_STRING([--enable-logsmanagement-tests], [Enable logsmanagement tests @<:@default disabled@:>@])],
|
|
,
|
|
[enable_logsmanagement_tests="no"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[plugin-cups],
|
|
[AS_HELP_STRING([--enable-plugin-cups], [enable cups plugin @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_plugin_cups="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[plugin-xenstat],
|
|
[AS_HELP_STRING([--enable-plugin-xenstat], [enable xenstat plugin @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_plugin_xenstat="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[exporting-kinesis],
|
|
[AS_HELP_STRING([--enable-exporting-kinesis], [enable kinesis exporting connector @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_exporting_kinesis="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[exporting-pubsub],
|
|
[AS_HELP_STRING([--enable-exporting-pubsub], [enable pubsub exporting connector @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_exporting_pubsub="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[exporting-prometheus-remote-write],
|
|
[AS_HELP_STRING([--enable-exporting-prometheus-remote-write], [enable prometheus remote write exporting connector @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_exporting_prometheus_remote_write="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[exporting-mongodb],
|
|
[AS_HELP_STRING([--enable-exporting-mongodb], [enable mongodb exporting @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_exporting_mongodb="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[pedantic],
|
|
[AS_HELP_STRING([--enable-pedantic], [enable pedantic compiler warnings @<:@default disabled@:>@])],
|
|
,
|
|
[enable_pedantic="no"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[accept4],
|
|
[AS_HELP_STRING([--disable-accept4], [System does not have accept4 @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_accept4="detect"]
|
|
)
|
|
AC_ARG_WITH(
|
|
[webdir],
|
|
[AS_HELP_STRING([--with-webdir], [location of webdir @<:@PKGDATADIR/web@:>@])],
|
|
[webdir="${withval}"],
|
|
[webdir="\$(pkgdatadir)/web"]
|
|
)
|
|
AC_ARG_WITH(
|
|
[libcap],
|
|
[AS_HELP_STRING([--with-libcap], [build with libcap @<:@default autodetect@:>@])],
|
|
,
|
|
[with_libcap="detect"]
|
|
)
|
|
AC_ARG_WITH(
|
|
[math],
|
|
[AS_HELP_STRING([--without-math], [build without math @<:@default enabled@:>@])],
|
|
,
|
|
[with_math="yes"]
|
|
)
|
|
AC_ARG_WITH(
|
|
[user],
|
|
[AS_HELP_STRING([--with-user], [use this user to drop privilege @<:@default nobody@:>@])],
|
|
,
|
|
[with_user="nobody"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[x86-sse],
|
|
[AS_HELP_STRING([--disable-x86-sse], [SSE/SS2 optimizations on x86 @<:@default enabled@:>@])],
|
|
,
|
|
[enable_x86_sse="yes"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[lto],
|
|
[AS_HELP_STRING([--enable-lto], [Link Time Optimizations @<:@default disabled@:>@])],
|
|
,
|
|
[enable_lto="no"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[openssl],
|
|
[AS_HELP_STRING([--enable-openssl], [Enable OpenSSL support @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_openssl="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[lz4],
|
|
[AS_HELP_STRING([--enable-lz4], [Enable LZ4 support @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_lz4="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[dbengine],
|
|
[AS_HELP_STRING([--disable-dbengine], [disable netdata dbengine @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_dbengine="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[jsonc],
|
|
[AS_HELP_STRING([--enable-jsonc], [Enable JSON-C support @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_jsonc="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[ebpf],
|
|
[AS_HELP_STRING([--disable-ebpf], [Disable eBPF support @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_ebpf="detect"]
|
|
)
|
|
AC_ARG_WITH(
|
|
[bundled-lws],
|
|
[AS_HELP_STRING([--with-bundled-lws], [Use the bundled version of libwebsockets library @<:@default use system library@:>@])],
|
|
[with_bundled_lws="yes"], [with_bundled_lws="no"]
|
|
)
|
|
AC_ARG_WITH(
|
|
[bundled-protobuf],
|
|
[AS_HELP_STRING([--with-bundled-protobuf],
|
|
[Uses the bundled version of Google Protocol Buffers @<:@default bundled if present@:>@])],
|
|
[with_bundled_protobuf="$withval"],
|
|
[with_bundled_protobuf="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[ml],
|
|
[AS_HELP_STRING([--enable-ml], [Enable anomaly detection @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_ml="detect"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[gtests],
|
|
[AS_HELP_STRING([--enable-gtests], [Enable google tests @<:@default no@:>@])],
|
|
,
|
|
[enable_gtests="no"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[aclk_ssl_debug],
|
|
[AS_HELP_STRING([--enable-aclk-ssl-debug], [Enables possibility for SSL key logging @<:@default no@:>@])],
|
|
[aclk_ssl_debug="yes"],
|
|
[aclk_ssl_debug="no"]
|
|
)
|
|
AC_ARG_ENABLE(
|
|
[h2o],
|
|
[AS_HELP_STRING([--disable-h2o], [Disable H2O webserver @<:@default autodetect@:>@])],
|
|
,
|
|
[enable_h2o="detect"]
|
|
)
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Enforce building with C99, bail early if we can't.
|
|
test "${ac_cv_prog_cc_c99}" = "no" && AC_MSG_ERROR([Netdata requires a compiler that supports C99 to build])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Check if cloud is enabled and if the functionality is available
|
|
|
|
AC_ARG_ENABLE(
|
|
[cloud],
|
|
[AS_HELP_STRING([--disable-cloud],
|
|
[Disables all cloud functionality])],
|
|
[ enable_cloud="$enableval" ],
|
|
[ enable_cloud="detect" ]
|
|
)
|
|
|
|
if test "${enable_cloud}" = "no"; then
|
|
AC_DEFINE([DISABLE_CLOUD], [1], [disable netdata cloud functionality])
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# C++ version check
|
|
|
|
# Check for C++17 support (optional)
|
|
# AX_CXX_COMPILE_STDCXX(17, noext, optional)
|
|
|
|
if test "x$HAVE_CXX17" != "x1"; then
|
|
# Check for C++11 support (optional)
|
|
AX_CXX_COMPILE_STDCXX(11, noext, optional)
|
|
fi
|
|
|
|
AC_MSG_CHECKING([c++ standard to use])
|
|
if test "x$HAVE_CXX17" = "x1"; then
|
|
have_cxx17="yes"
|
|
have_cxx11="yes"
|
|
CPP_STD_FLAG="-std=c++17"
|
|
cpp_std_to_use="c++17"
|
|
AM_CONDITIONAL([HAVE_CXX17], [true])
|
|
AM_CONDITIONAL([HAVE_CXX11], [true])
|
|
elif test "x$HAVE_CXX11" = "x1"; then
|
|
have_cxx17="no"
|
|
have_cxx11="yes"
|
|
CPP_STD_FLAG="-std=c++11"
|
|
cpp_std_to_use="c++11"
|
|
AM_CONDITIONAL([HAVE_CXX17], [false])
|
|
AM_CONDITIONAL([HAVE_CXX11], [true])
|
|
else
|
|
have_cxx17="no"
|
|
have_cxx11="no"
|
|
CPP_STD_FLAG=""
|
|
cpp_std_to_use="no c++"
|
|
AM_CONDITIONAL([HAVE_CXX17], [false])
|
|
AM_CONDITIONAL([HAVE_CXX11], [false])
|
|
fi
|
|
|
|
# PPC64LE needs -std=gnu++11 in order to build dlib. However, the rest of
|
|
# the agent's components use and have been tested only with -std=c++11.
|
|
# Skip ML compilation on that CPU until we reorganize and test the C++ flags.
|
|
if test "${host_cpu}" = "powerpc64le"; then
|
|
have_cxx17="no"
|
|
have_cxx11="no"
|
|
CPP_STD_FLAG=""
|
|
cpp_std_to_use="no c++ on powerpc64le"
|
|
AM_CONDITIONAL([HAVE_CXX17], [false])
|
|
AM_CONDITIONAL([HAVE_CXX11], [false])
|
|
fi
|
|
|
|
AC_MSG_RESULT([${cpp_std_to_use}])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# netdata required checks
|
|
|
|
# fails on centos6
|
|
#AX_CHECK_ENABLE_DEBUG()
|
|
|
|
AX_GCC_FUNC_ATTRIBUTE([returns_nonnull])
|
|
AX_GCC_FUNC_ATTRIBUTE([malloc])
|
|
AX_GCC_FUNC_ATTRIBUTE([noreturn])
|
|
AX_GCC_FUNC_ATTRIBUTE([noinline])
|
|
AX_GCC_FUNC_ATTRIBUTE([format])
|
|
AX_GCC_FUNC_ATTRIBUTE([warn_unused_result])
|
|
|
|
AC_CHECK_TYPES([struct timespec, clockid_t], [], [], [[#include <time.h>]])
|
|
AC_SEARCH_LIBS([clock_gettime], [rt posix4])
|
|
AC_CHECK_FUNCS([clock_gettime])
|
|
AC_CHECK_FUNCS([sched_setscheduler sched_getscheduler sched_getparam sched_get_priority_min sched_get_priority_max getpriority setpriority nice])
|
|
AC_CHECK_FUNCS([recvmmsg])
|
|
AC_CHECK_FUNCS([close_range])
|
|
|
|
AC_TYPE_INT8_T
|
|
AC_TYPE_INT16_T
|
|
AC_TYPE_INT32_T
|
|
AC_TYPE_INT64_T
|
|
AC_TYPE_UINT8_T
|
|
AC_TYPE_UINT16_T
|
|
AC_TYPE_UINT32_T
|
|
AC_TYPE_UINT64_T
|
|
AC_C_INLINE
|
|
AC_FUNC_STRERROR_R
|
|
AC_C__GENERIC
|
|
# AC_C_STMT_EXPR
|
|
AC_CANONICAL_HOST
|
|
AC_HEADER_MAJOR
|
|
AC_HEADER_RESOLV
|
|
|
|
AC_CHECK_HEADERS_ONCE([sys/prctl.h])
|
|
AC_CHECK_HEADERS_ONCE([sys/vfs.h])
|
|
AC_CHECK_HEADERS_ONCE([sys/statfs.h])
|
|
AC_CHECK_HEADERS_ONCE([linux/magic.h])
|
|
AC_CHECK_HEADERS_ONCE([sys/statvfs.h])
|
|
AC_CHECK_HEADERS_ONCE([sys/mount.h])
|
|
|
|
if test "${enable_accept4}" != "no"; then
|
|
AC_CHECK_FUNCS_ONCE(accept4)
|
|
fi
|
|
|
|
AC_CHECK_FUNCS_ONCE(malloc_usable_size)
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# operating system detection
|
|
|
|
originalCFLAGS="${CFLAGS}"
|
|
AC_MSG_CHECKING([operating system])
|
|
case "$host_os" in
|
|
freebsd*)
|
|
build_target=freebsd
|
|
OPTIONAL_OS_DEP_CFLAGS="-I/usr/local/include"
|
|
CFLAGS="${CFLAGS} ${OPTIONAL_OS_DEP_CFLAGS}"
|
|
LDFLAGS="${LDFLAGS} -L/usr/local/lib"
|
|
;;
|
|
darwin*)
|
|
build_target=macos
|
|
LDFLAGS="${LDFLAGS} -framework CoreFoundation -framework IOKit"
|
|
# -----------------------------------------------------------------------------
|
|
# Pull in OpenSSL properly if on macOS
|
|
if brew --prefix > /dev/null 2>&1; then
|
|
if brew --prefix --installed openssl > /dev/null 2>&1; then
|
|
HOMEBREW_OPENSSL_PREFIX=$(brew --prefix --installed openssl)
|
|
elif brew --prefix --installed openssl@3 > /dev/null 2>&1; then
|
|
HOMEBREW_OPENSSL_PREFIX=$(brew --prefix --installed openssl@3)
|
|
elif brew --prefix --installed openssl@1.1 > /dev/null 2>&1; then
|
|
HOMEBREW_OPENSSL_PREFIX=$(brew --prefix --installed openssl@1.1)
|
|
fi
|
|
if test -n "${HOMEBREW_OPENSSL_PREFIX}"; then
|
|
OPTIONAL_OS_DEP_CFLAGS="-I${HOMEBREW_OPENSSL_PREFIX}/include"
|
|
CFLAGS="${CFLAGS} ${OPTIONAL_OS_DEP_CFLAGS}"
|
|
LDFLAGS="${LDFLAGS} -L${HOMEBREW_OPENSSL_PREFIX}/lib"
|
|
fi
|
|
HOMEBREW_PREFIX=$(brew --prefix)
|
|
OPTIONAL_OS_DEP_CFLAGS="${OPTIONAL_OS_DEP_CFLAGS} -I${HOMEBREW_PREFIX}/include"
|
|
CFLAGS="${CFLAGS} -I${HOMEBREW_PREFIX}/include"
|
|
LDFLAGS="${LDFLAGS} -L${HOMEBREW_PREFIX}/lib"
|
|
fi
|
|
;;
|
|
*)
|
|
build_target=linux
|
|
;;
|
|
esac
|
|
|
|
AM_CONDITIONAL([FREEBSD], [test "${build_target}" = "freebsd"])
|
|
if test "${build_target}" = "freebsd"
|
|
then
|
|
AC_DEFINE([COMPILED_FOR_FREEBSD], [1], [Compiled for FreeBSD])
|
|
fi
|
|
|
|
AM_CONDITIONAL([MACOS], [test "${build_target}" = "macos"])
|
|
if test "${build_target}" = "macos"
|
|
then
|
|
AC_DEFINE([COMPILED_FOR_MACOS], [1], [Compiled for MacOS])
|
|
fi
|
|
|
|
AM_CONDITIONAL([LINUX], [test "${build_target}" = "linux"])
|
|
if test "${build_target}" = "linux"
|
|
then
|
|
AC_DEFINE([COMPILED_FOR_LINUX], [1], [Compiled for Linux])
|
|
fi
|
|
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_LOCAL_LISTENERS], [test "${build_target}" = "linux"])
|
|
|
|
AC_MSG_RESULT([Host OS: ${build_target}])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# hardening
|
|
|
|
HARDENING_CFLAGS=""
|
|
|
|
if ! echo "${originalCFLAGS}" | grep -q '\-fstack-protector'; then
|
|
AX_CHECK_COMPILE_FLAG(
|
|
[-fstack-protector-strong],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -fstack-protector-strong"],
|
|
[AX_CHECK_COMPILE_FLAG(
|
|
[-fstack-protector],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -fstack-protector"],
|
|
,
|
|
[-Werror],
|
|
)],
|
|
[-Werror],
|
|
)
|
|
fi
|
|
|
|
if ! echo "${originalCFLAGS}" | grep -q '\-fno-stack-clash-protection'; then
|
|
AX_CHECK_COMPILE_FLAG(
|
|
[-fstack-clash-protection],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -fstack-clash-protection"],
|
|
,
|
|
[-Werror],
|
|
)
|
|
fi
|
|
|
|
if ! echo "${originalCFLAGS}" | grep -q '\-fcf-protection'; then
|
|
AX_CHECK_COMPILE_FLAG(
|
|
[-fcf-protection=full],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -fcf-protection=full"],
|
|
,
|
|
[-Werror],
|
|
)
|
|
fi
|
|
|
|
if ! echo "${originalCFLAGS}" | grep -q '\-mbranch-protection'; then
|
|
AX_CHECK_COMPILE_FLAG(
|
|
[-mbranch-protection=standard],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -mbranch-protection=standard"],
|
|
,
|
|
[-Werror],
|
|
)
|
|
fi
|
|
|
|
if ! echo "${originalCFLAGS}" | grep -q '\-D_FORTIFY_SOURCE'; then
|
|
# This complex set of checks is needed because there is no clean
|
|
# way to verify _FORTIFY_SOURCE support without having to check for
|
|
# the required compiler builtins.
|
|
AC_CHECK_DECLS(
|
|
[__builtin_constant_p, __builtin_object_size, __builtin___memcpy_chk, __builtin___memmove_chk, __builtin___mempcpy_chk,
|
|
__builtin___memset_chk, __builtin___snprintf_chk, __builtin___sprintf_chk, __builtin___stpcpy_chk, __builtin___strcat_chk,
|
|
__builtin___strcpy_chk, __builtin___strncat_chk, __builtin___strncpy_chk, __builtin___vsnprintf_chk, __builtin___vsprintf_chk],
|
|
[HAVE_FORTIFY_SOURCE=2]
|
|
)
|
|
|
|
if test "x${HAVE_FORTIFY_SOURCE}" = "x2" && echo "${originalCFLAGS}" | grep -qv '\-O0'; then
|
|
AC_CHECK_DECL(
|
|
__builtin_dynamic_object_size,
|
|
[AX_CHECK_COMPILE_FLAG(
|
|
[-D_FORTIFY_SOURCE=3],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -D_FORTIFY_SOURCE=3"],
|
|
,
|
|
[-Werror],
|
|
)],
|
|
[AX_CHECK_COMPILE_FLAG(
|
|
[-D_FORTIFY_SOURCE=2],
|
|
[HARDENING_CFLAGS="${HARDENING_CFLAGS} -D_FORTIFY_SOURCE=2"],
|
|
,
|
|
[-Werror],
|
|
)],
|
|
)
|
|
fi
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# backtrace
|
|
|
|
AC_SEARCH_LIBS([backtrace], [execinfo], [AC_DEFINE([HAVE_BACKTRACE], [1], [backtrace availability])])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# pthreads
|
|
|
|
ACX_PTHREAD(, [AC_MSG_ERROR([Cannot initialize pthread environment])])
|
|
LIBS="${PTHREAD_LIBS} ${LIBS}"
|
|
CFLAGS="${CFLAGS} ${PTHREAD_CFLAGS}"
|
|
CC="${PTHREAD_CC}"
|
|
|
|
AC_CHECK_LIB(
|
|
[pthread],
|
|
[pthread_getname_np],
|
|
[AC_DEFINE([HAVE_PTHREAD_GETNAME_NP], [1], [Is set if pthread_getname_np is available])]
|
|
)
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libdatachannel
|
|
|
|
AC_CHECK_LIB([datachannel], [rtcCreatePeerConnection],
|
|
[LIBDATACHANNEL_FOUND=yes],
|
|
[LIBDATACHANNEL_FOUND=no])
|
|
|
|
if test "x$LIBDATACHANNEL_FOUND" = "xyes"; then
|
|
AC_DEFINE([HAVE_LIBDATACHANNEL], [1], [libdatachannel usability])
|
|
OPTIONAL_DATACHANNEL_LIBS="-ldatachannel"
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libm
|
|
|
|
AC_ARG_VAR([MATH_CFLAGS], [C compiler flags for math])
|
|
AC_ARG_VAR([MATH_LIBS], [linker flags for math])
|
|
if test -z "${MATH_LIBS}"; then
|
|
AC_CHECK_LIB(
|
|
[m],
|
|
[sin],
|
|
[MATH_LIBS="-lm"]
|
|
)
|
|
fi
|
|
test "${with_math}" = "yes" -a -z "${MATH_LIBS}" && AC_MSG_ERROR([math required but not found])
|
|
|
|
AC_MSG_CHECKING([if libm should be used])
|
|
if test "${with_math}" != "no" -a ! -z "${MATH_LIBS}"; then
|
|
with_math="yes"
|
|
AC_DEFINE([STORAGE_WITH_MATH], [1], [math usability])
|
|
OPTIONAL_MATH_CFLAGS="${MATH_CFLAGS}"
|
|
OPTIONAL_MATH_LIBS="${MATH_LIBS}"
|
|
else
|
|
with_math="no"
|
|
fi
|
|
AC_MSG_RESULT([${with_math}])
|
|
|
|
AC_CHECK_FUNCS([isfinite])
|
|
AC_CHECK_FUNCS([finite])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libuv multi-platform support library with a focus on asynchronous I/O
|
|
# TODO: check version, uv_fs_scandir_next only available in version >= 1.0
|
|
|
|
AC_CHECK_LIB(
|
|
[uv],
|
|
[uv_fs_scandir_next],
|
|
[UV_LIBS="-luv"]
|
|
)
|
|
test -z "${UV_LIBS}" && \
|
|
AC_MSG_ERROR([libuv required but not found. Try installing 'libuv1-dev' or 'libuv-devel'.])
|
|
OPTIONAL_UV_CFLAGS="${UV_CFLAGS}"
|
|
OPTIONAL_UV_LIBS="${UV_LIBS}"
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# lz4
|
|
|
|
AC_CHECK_LIB(
|
|
[lz4],
|
|
[LZ4_createStream],
|
|
[LZ4_LIBS_FAST="-llz4"]
|
|
)
|
|
|
|
AC_CHECK_LIB(
|
|
[lz4],
|
|
[LZ4_compress_fast_continue],
|
|
[LZ4_LIBS="-llz4"]
|
|
)
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libcurl
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBCURL],
|
|
[libcurl],
|
|
[AC_CHECK_LIB(
|
|
[curl],
|
|
[curl_easy_init],
|
|
[have_libcurl=yes],
|
|
[have_libcurl=no]
|
|
)],
|
|
[have_libcurl=no]
|
|
)
|
|
|
|
if test "x$have_libcurl" = "xyes"; then
|
|
AC_DEFINE([HAVE_CURL], [1], [libcurl usability])
|
|
OPTIONAL_CURL_LIBS="-lcurl"
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# PCRE2
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBPCRE2],
|
|
[libpcre2-8],
|
|
[AC_CHECK_LIB(
|
|
[pcre2-8],
|
|
[pcre2_compile_8],
|
|
[have_libpcre2=yes],
|
|
[have_libpcre2=no]
|
|
)],
|
|
[have_libpcre2=no]
|
|
)
|
|
|
|
if test "x$have_libpcre2" = "xyes"; then
|
|
AC_DEFINE([HAVE_PCRE2], [1], [PCRE2 usability])
|
|
OPTIONAL_PCRE2_LIBS="-lpcre2-8"
|
|
fi
|
|
|
|
AM_CONDITIONAL([ENABLE_LOG2JOURNAL], [test "${have_libpcre2}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# zstd
|
|
|
|
AC_CHECK_LIB([zstd], [ZSTD_createCStream, ZSTD_createDStream],
|
|
[LIBZSTD_FOUND=yes],
|
|
[LIBZSTD_FOUND=no])
|
|
|
|
if test "x$LIBZSTD_FOUND" = "xyes"; then
|
|
AC_DEFINE([ENABLE_ZSTD], [1], [libzstd usability])
|
|
OPTIONAL_ZSTD_LIBS="-lzstd"
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# brotli
|
|
|
|
AC_CHECK_LIB([brotlienc], [BrotliEncoderCreateInstance, BrotliEncoderCompressStream],
|
|
[LIBBROTLIENC_FOUND=yes],
|
|
[LIBBROTLIENC_FOUND=no])
|
|
|
|
if test "x$LIBBROTLIENC_FOUND" = "xyes"; then
|
|
AC_DEFINE([ENABLE_BROTLIENC], [1], [libbrotlienc usability])
|
|
OPTIONAL_BROTLIENC_LIBS="-lbrotlienc"
|
|
fi
|
|
|
|
AC_CHECK_LIB([brotlidec], [BrotliDecoderCreateInstance, BrotliDecoderDecompressStream],
|
|
[LIBBROTLIDEC_FOUND=yes],
|
|
[LIBBROTLIDEC_FOUND=no])
|
|
|
|
if test "x$LIBBROTLIDEC_FOUND" = "xyes"; then
|
|
AC_DEFINE([ENABLE_BROTLIDEC], [1], [libbrotlidec usability])
|
|
OPTIONAL_BROTLIDEC_LIBS="-lbrotlidec"
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# zlib
|
|
|
|
PKG_CHECK_MODULES(
|
|
[ZLIB],
|
|
[zlib],
|
|
[have_zlib=yes],
|
|
[have_zlib=no]
|
|
)
|
|
test "${have_zlib}" != "yes" && AC_MSG_ERROR([zlib required but not found. Try installing 'zlib1g-dev' or 'zlib-devel'.])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libuuid
|
|
|
|
PKG_CHECK_MODULES(
|
|
[UUID],
|
|
[uuid],
|
|
[have_uuid=yes],
|
|
[AC_MSG_ERROR([libuuid required but not found. Try installing 'uuid-dev' or 'libuuid-devel'.])]
|
|
)
|
|
OPTIONAL_UUID_CFLAGS="${UUID_CFLAGS}"
|
|
OPTIONAL_UUID_LIBS="${UUID_LIBS}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# OpenSSL Cryptography and SSL/TLS Toolkit
|
|
|
|
AC_CHECK_LIB(
|
|
[crypto],
|
|
[SHA256_Init],
|
|
[SSL_LIBS="-lcrypto -lssl"]
|
|
)
|
|
|
|
AC_CHECK_LIB(
|
|
[crypto],
|
|
[X509_VERIFY_PARAM_set1_host],
|
|
[ssl_host_validation="yes"],
|
|
[ssl_host_validation="no"]
|
|
)
|
|
|
|
test -z "${SSL_LIBS}" || \
|
|
AC_DEFINE([HAVE_CRYPTO], [1], [libcrypto availability])
|
|
|
|
if test "${ssl_host_validation}" = "no"; then
|
|
AC_DEFINE([HAVE_X509_VERIFY_PARAM_set1_host], [0], [ssl host validation])
|
|
AC_MSG_WARN([DISABLING SSL HOSTNAME VALIDATION BECAUSE IT IS NOT AVAILABLE ON THIS SYSTEM.])
|
|
else
|
|
AC_DEFINE([HAVE_X509_VERIFY_PARAM_set1_host], [1], [ssl host validation])
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# JSON-C library
|
|
|
|
PKG_CHECK_MODULES([JSON],[json-c],AC_CHECK_LIB(
|
|
[json-c],
|
|
[json_object_get_type],
|
|
[JSONC_LIBS="-ljson-c"]),AC_CHECK_LIB(
|
|
[json],
|
|
[json_object_get_type],
|
|
[JSONC_LIBS="-ljson"])
|
|
)
|
|
|
|
OPTIONAL_JSONC_LIBS="${JSONC_LIBS}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# YAML library
|
|
|
|
AC_CHECK_LIB(
|
|
[yaml],
|
|
[yaml_parser_initialize],
|
|
[YAML_LIBS="-lyaml"]
|
|
)
|
|
|
|
OPTIONAL_YAML_LIBS="${YAML_LIBS}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# DB engine and OpenSSL
|
|
|
|
test "${enable_dbengine}" = "yes" -a -z "${LZ4_LIBS}" && \
|
|
AC_MSG_ERROR([liblz4 required but not found. Try installing 'liblz4-dev' or 'lz4-devel'.])
|
|
|
|
AC_C_BIGENDIAN([],
|
|
[LIBJUDY_CFLAGS="-DJU_LITTLE_ENDIAN"],
|
|
[AC_MSG_ERROR([Could not find out system endiannnes])])
|
|
|
|
AC_CHECK_SIZEOF(void *)
|
|
if test "$ac_cv_sizeof_void_p" = 8; then
|
|
AC_MSG_RESULT(Detected 64-bit Build Environment)
|
|
LIBJUDY_CFLAGS="$LIBJUDY_CFLAGS -DJU_64BIT"
|
|
else
|
|
AC_MSG_RESULT(Detected 32-bit Build Environment)
|
|
LIBJUDY_CFLAGS="$LIBJUDY_CFLAGS -UJU_64BIT"
|
|
fi
|
|
|
|
AC_SUBST([LIBJUDY_CFLAGS])
|
|
|
|
JUDY_CFLAGS="-I \$(abs_top_srcdir)/libnetdata/libjudy/src"
|
|
|
|
test "${enable_openssl}" = "yes" -a -z "${SSL_LIBS}" && \
|
|
AC_MSG_ERROR([OpenSSL required but not found. Try installing 'libssl-dev' or 'openssl-devel'.])
|
|
|
|
test "${enable_dbengine}" = "yes" -a -z "${SSL_LIBS}" && \
|
|
AC_MSG_ERROR([OpenSSL required for DBENGINE but not found. Try installing 'libssl-dev' or 'openssl-devel'.])
|
|
|
|
AC_MSG_CHECKING([if netdata dbengine should be used])
|
|
if test "${enable_dbengine}" != "no" -a "${UV_LIBS}" -a "${LZ4_LIBS}" -a "${SSL_LIBS}"; then
|
|
enable_dbengine="yes"
|
|
AC_DEFINE([ENABLE_DBENGINE], [1], [netdata dbengine usability])
|
|
OPTIONAL_LZ4_CFLAGS="${LZ4_CFLAGS}"
|
|
OPTIONAL_LZ4_LIBS="${LZ4_LIBS}"
|
|
OPTIONAL_SSL_CFLAGS="${SSL_CFLAGS}"
|
|
OPTIONAL_SSL_LIBS="${SSL_LIBS}"
|
|
else
|
|
enable_dbengine="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_dbengine}])
|
|
AM_CONDITIONAL([ENABLE_DBENGINE], [test "${enable_dbengine}" = "yes"])
|
|
|
|
AC_MSG_CHECKING([if openssl should be used])
|
|
if test "${enable_openssl}" != "no" -a "${SSL_LIBS}"; then
|
|
enable_openssl="yes"
|
|
AC_DEFINE([ENABLE_OPENSSL], [1], [openssl usability])
|
|
OPTIONAL_SSL_CFLAGS="${SSL_CFLAGS}"
|
|
OPTIONAL_SSL_LIBS="${SSL_LIBS}"
|
|
else
|
|
enable_openssl="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_openssl}])
|
|
AM_CONDITIONAL([ENABLE_OPENSSL], [test "${enable_openssl}" = "yes"])
|
|
|
|
AC_MSG_CHECKING([if lz4 should be used])
|
|
if test "${enable_lz4}" != "no"; then
|
|
if test "${LZ4_LIBS_FAST}"; then
|
|
LIBS_BKP="${LIBS}"
|
|
LIBS="${LZ4_LIBS_FAST}"
|
|
AC_TRY_LINK(
|
|
[ #include <lz4.h> ],
|
|
[
|
|
LZ4_stream_t* stream = LZ4_createStream();
|
|
],
|
|
[ enable_lz4="yes"],
|
|
[ enable_lz4="no" ]
|
|
)
|
|
LIBS="${LIBS_BKP}"
|
|
if test "${enable_lz4}" == "yes"; then
|
|
OPTIONAL_LZ4_LIBS="${LZ4_LIBS_FAST}"
|
|
AC_DEFINE([ENABLE_LZ4], [1], [lz4 usability])
|
|
fi
|
|
else
|
|
if test "${enable_lz4}" == "yes"; then
|
|
AC_MSG_ERROR([liblz4 with version >= 1.9.0 required to enable lz4. Try installing the required version of 'liblz4-dev' or 'liblz4-devel'.])
|
|
enable_lz4="no"
|
|
fi
|
|
enable_lz4="no"
|
|
fi
|
|
else
|
|
enable_lz4="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_lz4}])
|
|
AM_CONDITIONAL([ENABLE_LZ4], [test "${enable_lz4}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# JSON-C
|
|
|
|
if test "${enable_jsonc}" != "no" -a -z "${JSONC_LIBS}"; then
|
|
# Try and detect manual static build presence (from netdata-installer.sh)
|
|
AC_MSG_CHECKING([if statically built json-c is present])
|
|
HAVE_libjson_c_a="no"
|
|
if test -f "externaldeps/jsonc/libjson-c.a"; then
|
|
LIBS_BKP="${LIBS}"
|
|
LIBS="externaldeps/jsonc/libjson-c.a"
|
|
AC_LINK_IFELSE([AC_LANG_SOURCE([[#include "externaldeps/jsonc/json-c/json.h"
|
|
int main (int argc, char **argv) {
|
|
struct json_object *jobj;
|
|
char *str = "{ \"msg-type\": \"random\" }";
|
|
jobj = json_tokener_parse(str);
|
|
json_object_get_type(jobj);
|
|
}]])],
|
|
[HAVE_libjson_c_a="yes"],
|
|
[HAVE_libjson_c_a="no"])
|
|
LIBS="${LIBS_BKP}"
|
|
fi
|
|
|
|
if test "${HAVE_libjson_c_a}" = "yes"; then
|
|
AC_DEFINE([LINK_STATIC_JSONC], [1], [static json-c should be used])
|
|
JSONC_LIBS="static"
|
|
OPTIONAL_JSONC_STATIC_CFLAGS="-I \$(abs_top_srcdir)/externaldeps/jsonc"
|
|
fi
|
|
AC_MSG_RESULT([${HAVE_libjson_c_a}])
|
|
fi
|
|
AM_CONDITIONAL([LINK_STATIC_JSONC], [test "${JSONC_LIBS}" = "static"])
|
|
|
|
test "${enable_jsonc}" = "yes" -a -z "${JSONC_LIBS}" && \
|
|
AC_MSG_ERROR([JSON-C required but not found. Try installing 'libjson-c-dev' or 'json-c'.])
|
|
|
|
AC_MSG_CHECKING([if json-c should be used])
|
|
if test "${enable_jsonc}" != "no" -a "${JSONC_LIBS}"; then
|
|
enable_jsonc="yes"
|
|
AC_DEFINE([ENABLE_JSONC], [1], [netdata json-c usability])
|
|
else
|
|
enable_jsonc="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_jsonc}])
|
|
AM_CONDITIONAL([ENABLE_JSONC], [test "${enable_jsonc}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libyaml
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBYAML],
|
|
[yaml-0.1],
|
|
[AC_CHECK_LIB(
|
|
[yaml],
|
|
[yaml_parser_initialize],
|
|
[have_libyaml=yes],
|
|
[have_libyaml=no]
|
|
)],
|
|
[have_libyaml=no]
|
|
)
|
|
|
|
if test "x$have_libyaml" = "xyes"; then
|
|
AC_DEFINE([HAVE_LIBYAML], [1], [libyaml usability])
|
|
OPTIONAL_YAML_LIBS="-lyaml"
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# YAML
|
|
|
|
if test -z "${YAML_LIBS}"; then
|
|
# Try and detect manual static build presence (from netdata-installer.sh)
|
|
AC_MSG_CHECKING([if statically built libyaml is present])
|
|
HAVE_libyaml_a="no"
|
|
if test -f "externaldeps/libyaml/libyaml.a"; then
|
|
LIBS_BKP="${LIBS}"
|
|
LIBS="externaldeps/libyaml/libyaml.a"
|
|
AC_LINK_IFELSE([AC_LANG_SOURCE([[#include "externaldeps/libyaml/yaml.h"
|
|
int main (int argc, char **argv) {
|
|
yaml_parser_t parser;
|
|
yaml_parser_initialize(&parser);
|
|
}]])],
|
|
[HAVE_libyaml_a="yes"],
|
|
[HAVE_libyaml_a="no"])
|
|
LIBS="${LIBS_BKP}"
|
|
fi
|
|
|
|
if test "${HAVE_libyaml_a}" = "yes"; then
|
|
AC_DEFINE([LINK_STATIC_YAML], [1], [static yaml should be used])
|
|
YAML_LIBS="static"
|
|
OPTIONAL_YAML_STATIC_CFLAGS="-I \$(abs_top_srcdir)/externaldeps/libyaml"
|
|
fi
|
|
AC_MSG_RESULT([${HAVE_libyaml_a}])
|
|
fi
|
|
AM_CONDITIONAL([LINK_STATIC_YAML], [test "${YAML_LIBS}" = "static"])
|
|
|
|
test -z "${YAML_LIBS}" && \
|
|
AC_MSG_ERROR([LIBYAML required but not found. Try installing 'libyaml-dev'.])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# compiler options
|
|
|
|
AC_ARG_VAR([SSE_CANDIDATE], [C compiler flags for SSE])
|
|
AS_CASE([$host_cpu],
|
|
[i?86], [SSE_CANDIDATE="yes"]
|
|
)
|
|
AC_SUBST([SSE_CANDIDATE])
|
|
if test "${SSE_CANDIDATE}" = "yes" -a "${enable_x86_sse}" = "yes"; then
|
|
opt="-msse2 -mfpmath=sse"
|
|
AX_CHECK_COMPILE_FLAG(${opt}, [CFLAGS="${CFLAGS} ${opt}"], [])
|
|
fi
|
|
|
|
if test "${GCC}" = "yes"; then
|
|
AC_DEFINE_UNQUOTED([likely(x)], [__builtin_expect(!!(x), 1)], [gcc branch optimization])
|
|
AC_DEFINE_UNQUOTED([unlikely(x)], [__builtin_expect(!!(x), 0)], [gcc branch optimization])
|
|
else
|
|
AC_DEFINE_UNQUOTED([likely(x)], [(x)], [gcc branch optimization])
|
|
AC_DEFINE_UNQUOTED([unlikely(x)], [(x)], [gcc branch optimization])
|
|
fi
|
|
|
|
if test "${GCC}" = "yes"; then
|
|
AC_DEFINE([__always_unused], [__attribute__((unused))], [gcc unused attribute])
|
|
AC_DEFINE([__maybe_unused], [__attribute__((unused))], [gcc unused attribute])
|
|
else
|
|
AC_DEFINE([__always_unused], [], [dummy unused attribute])
|
|
AC_DEFINE([__maybe_unused], [], [dummy unused attribute])
|
|
fi
|
|
|
|
if test "${enable_pedantic}" = "yes"; then
|
|
enable_strict="yes"
|
|
CFLAGS="${CFLAGS} -pedantic -Wall -Wextra -Wno-long-long"
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# dlsym check
|
|
|
|
AC_MSG_CHECKING(whether we can use dlsym)
|
|
OLD_LIBS="${LIBS}"
|
|
LIBS="-ldl"
|
|
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
#include <dlfcn.h>
|
|
static void *(*libc_malloc)(size_t);
|
|
int main() {
|
|
libc_malloc = dlsym(RTLD_NEXT, "malloc");
|
|
}
|
|
]])], CAN_USE_DLSYM=yes, CAN_USE_DLSYM=no)
|
|
LIBS="${OLD_LIBS}"
|
|
AC_MSG_RESULT($CAN_USE_DLSYM)
|
|
|
|
if test "x$CAN_USE_DLSYM" = xyes; then
|
|
AC_DEFINE([HAVE_DLSYM], [1], [dlsym usability])
|
|
OPTIONAL_DL_LIBS="-ldl"
|
|
fi
|
|
AC_SUBST([OPTIONAL_DL_LIBS])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# memory allocation library
|
|
|
|
AC_MSG_CHECKING([for memory allocator])
|
|
TS_CHECK_JEMALLOC
|
|
if test "$has_jemalloc" = "1"; then
|
|
AC_DEFINE([ENABLE_JEMALLOC], [1], [compile and link with jemalloc])
|
|
AC_MSG_RESULT([jemalloc])
|
|
else
|
|
TS_CHECK_TCMALLOC
|
|
if test "$has_tcmalloc" = "1"; then
|
|
AC_DEFINE([ENABLE_TCMALLOC], [1], [compile and link with tcmalloc])
|
|
AC_MSG_RESULT([tcmalloc])
|
|
else
|
|
AC_MSG_RESULT([system])
|
|
AC_C_MALLOPT
|
|
AC_C_MALLINFO
|
|
fi
|
|
fi
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# libcap
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBCAP],
|
|
[libcap],
|
|
[AC_CHECK_LIB([cap], [cap_get_proc, cap_set_proc],
|
|
[AC_CHECK_HEADER(
|
|
[sys/capability.h],
|
|
[have_libcap=yes],
|
|
[have_libcap=no]
|
|
)],
|
|
[have_libcap=no]
|
|
)],
|
|
[have_libcap=no]
|
|
)
|
|
test "${with_libcap}" = "yes" -a "${have_libcap}" != "yes" && AC_MSG_ERROR([libcap required but not found.])
|
|
|
|
AC_MSG_CHECKING([if libcap should be used])
|
|
if test "${with_libcap}" != "no" -a "${have_libcap}" = "yes"; then
|
|
with_libcap="yes"
|
|
AC_DEFINE([HAVE_CAPABILITY], [1], [libcap usability])
|
|
OPTIONAL_LIBCAP_CFLAGS="${LIBCAP_CFLAGS}"
|
|
OPTIONAL_LIBCAP_LIBS="${LIBCAP_LIBS}"
|
|
else
|
|
with_libcap="no"
|
|
fi
|
|
AC_MSG_RESULT([${with_libcap}])
|
|
AM_CONDITIONAL([ENABLE_CAPABILITY], [test "${with_libcap}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# H2O related
|
|
|
|
can_build_h2o="no"
|
|
if test "${enable_h2o}" != "no"; then
|
|
can_build_h2o="yes"
|
|
AC_MSG_CHECKING([can build H2O])
|
|
if test -z "${UV_LIBS}"; then
|
|
can_build_h2o="no"
|
|
fi
|
|
if test -n "${SSL_LIBS}"; then
|
|
OPTIONAL_SSL_CFLAGS="${SSL_CFLAGS}"
|
|
OPTIONAL_SSL_LIBS="${SSL_LIBS}"
|
|
else
|
|
can_build_h2o="no"
|
|
fi
|
|
AC_MSG_RESULT([${can_build_h2o}])
|
|
|
|
if test "${can_build_h2o}" = "no" -a "${enable_h2o}" = "yes"; then
|
|
AC_MSG_ERROR([H2O was requested but it cannot be built])
|
|
fi
|
|
|
|
if test "${can_build_h2o}" = "yes"; then
|
|
AC_DEFINE([ENABLE_H2O], [1], [H2O web server])
|
|
H2O_CFLAGS="-Wno-unused-result -Wno-misleading-indentation -Wno-format-security -Wno-format -Wno-unused-function -Wno-unused-parameter -Wno-type-limits -Wno-unused-but-set-variable -Wno-implicit-fallthrough -I\$(abs_top_srcdir)/web/server/h2o/libh2o/include -I\$(abs_top_srcdir)/web/server/h2o/libh2o/deps/picotls/include -I\$(abs_top_srcdir)/web/server/h2o/libh2o/deps/quicly/include -DH2O_USE_LIBUV=0"
|
|
fi
|
|
fi
|
|
AM_CONDITIONAL([ENABLE_H2O], [test "${can_build_h2o}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# ACLK
|
|
|
|
bundled_proto_avail="no"
|
|
if test "${with_bundled_protobuf}" != "no"; then
|
|
AC_MSG_CHECKING([is bundled protobuf available])
|
|
if test -f "externaldeps/protobuf/src/protoc"; then
|
|
bundled_proto_avail="yes"
|
|
fi
|
|
AC_MSG_RESULT([${bundled_proto_avail}])
|
|
if test "${with_bundled_protobuf}" == "yes" -a "${bundled_proto_avail}" != "yes"; then
|
|
AC_MSG_ERROR([Bundled protobuf requested using --with-bundled-protobuf but it cannot be used/found])
|
|
fi
|
|
if test "${with_bundled_protobuf}" == "detect" -a "${bundled_proto_avail}" == "yes"; then
|
|
with_bundled_protobuf="yes"
|
|
fi
|
|
fi
|
|
|
|
AM_CONDITIONAL([MQTT_WSS_DEBUG], [test "${aclk_ssl_debug}" = "yes"])
|
|
if test "${aclk_ssl_debug}" = "yes"; then
|
|
AC_DEFINE([MQTT_WSS_DEBUG], [1], [ACLK SSL allow debugging])
|
|
fi
|
|
|
|
if test "${with_bundled_protobuf}" != "yes"; then
|
|
PKG_CHECK_MODULES(
|
|
[PROTOBUF],
|
|
[protobuf >= 3],
|
|
[have_libprotobuf=yes],
|
|
[have_libprotobuf=no]
|
|
)
|
|
|
|
AC_PATH_PROG([PROTOC], [protoc], [no])
|
|
AS_IF(
|
|
[test x"${PROTOC}" == x"no"],
|
|
[have_protoc=no],
|
|
[have_protoc=yes]
|
|
)
|
|
else
|
|
AC_MSG_NOTICE([using bundled protobuf])
|
|
AC_DEFINE([BUNDLED_PROTOBUF], [1], [Using a bundled copy of protobuf])
|
|
PROTOC="\$(abs_top_srcdir)/externaldeps/protobuf/src/protoc"
|
|
PROTOBUF_CFLAGS="-I \$(abs_top_srcdir)/externaldeps/protobuf/src"
|
|
PROTOBUF_LIBS="\$(abs_top_srcdir)/externaldeps/protobuf/src/.libs/libprotobuf.a"
|
|
have_libprotobuf="yes"
|
|
have_protoc="yes"
|
|
fi
|
|
|
|
AC_PATH_PROG([CXX_BINARY], [${CXX}], [no])
|
|
AS_IF(
|
|
[test x"${CXX_BINARY}" == x"no"],
|
|
[have_CXX_compiler=no],
|
|
[have_CXX_compiler=yes]
|
|
)
|
|
|
|
if test "${have_libprotobuf}" == "yes" && test "${have_CXX_compiler}" == "yes"; then
|
|
AC_DEFINE([HAVE_PROTOBUF], [1], [Protobuf is available])
|
|
fi
|
|
|
|
AC_MSG_CHECKING([if Cloud functionality should be enabled])
|
|
AC_MSG_RESULT([${enable_cloud}])
|
|
|
|
if test "$enable_cloud" != "no"; then
|
|
AC_MSG_NOTICE([Checking if ACLK can be built])
|
|
can_enable_ng="yes"
|
|
AC_MSG_CHECKING([if git submodules present for ACLK])
|
|
if test -f "mqtt_websockets/src/mqtt_wss_client.c"; then
|
|
AC_MSG_RESULT([yes])
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
can_enable_ng="no"
|
|
fi
|
|
AC_MSG_CHECKING([if SSL available for ACLK])
|
|
if test -n "${SSL_LIBS}"; then
|
|
AC_MSG_RESULT([yes])
|
|
OPTIONAL_SSL_CFLAGS="${SSL_CFLAGS}"
|
|
OPTIONAL_SSL_LIBS="${SSL_LIBS}"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
fi
|
|
AC_MSG_CHECKING([if JSON-C available for ACLK])
|
|
if test "$enable_jsonc" != "yes"; then
|
|
AC_MSG_RESULT([no])
|
|
can_enable_ng="no"
|
|
else
|
|
AC_MSG_RESULT([yes])
|
|
fi
|
|
|
|
AC_MSG_CHECKING([if protobuf available for ACLK New Cloud Protocol])
|
|
if test "${have_libprotobuf}" != "yes"; then
|
|
AC_MSG_RESULT([no])
|
|
can_enable_ng="no"
|
|
else
|
|
AC_MSG_RESULT([yes])
|
|
fi
|
|
AC_MSG_CHECKING([if protoc available for ACLK New Cloud Protocol])
|
|
if test "${have_protoc}" != "yes"; then
|
|
AC_MSG_RESULT([no])
|
|
can_enable_ng="no"
|
|
else
|
|
AC_MSG_RESULT([yes])
|
|
fi
|
|
AC_MSG_CHECKING([if C++ compiler available for ACLK New Cloud Protocol])
|
|
if test "${have_CXX_compiler}" != "yes"; then
|
|
AC_MSG_RESULT([no])
|
|
can_enable_ng="no"
|
|
else
|
|
AC_MSG_RESULT([yes])
|
|
fi
|
|
|
|
AC_MSG_CHECKING([ACLK Next Generation can be built])
|
|
AC_MSG_RESULT([${can_enable_ng}])
|
|
if test "$can_enable_ng" = "no" -a "$enable_cloud" = "yes"; then
|
|
AC_MSG_ERROR([You have requested --with-cloud but ACLK can't be built. See reasons in lines above])
|
|
fi
|
|
if test "$can_enable_ng" = "yes"; then
|
|
enable_aclk="yes"
|
|
AC_DEFINE([ENABLE_ACLK], [1], [netdata ACLK])
|
|
OPTIONAL_ACLK_CFLAGS="-I \$(abs_top_srcdir)/mqtt_websockets/src/include -I \$(abs_top_srcdir)/mqtt_websockets/c-rbuf/include -I \$(abs_top_srcdir)/aclk/aclk-schemas"
|
|
OPTIONAL_PROTOBUF_CFLAGS="${PROTOBUF_CFLAGS}"
|
|
OPTIONAL_PROTOBUF_LIBS="${PROTOBUF_LIBS}"
|
|
fi
|
|
fi
|
|
|
|
if test "$enable_cloud" = "yes" -a "$enable_aclk" != "yes"; then
|
|
AC_MSG_ERROR([ACLK can't be built but --enable-cloud was requested])
|
|
fi
|
|
|
|
AC_SUBST([enable_cloud])
|
|
AC_SUBST([enable_aclk])
|
|
AM_CONDITIONAL([ENABLE_ACLK], [test "${enable_aclk}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# apps.plugin
|
|
|
|
AC_MSG_CHECKING([if apps.plugin should be enabled])
|
|
if test "${build_target}" != "macos"; then
|
|
AC_DEFINE([ENABLE_APPS_PLUGIN], [1], [apps.plugin])
|
|
enable_plugin_apps="yes"
|
|
else
|
|
enable_plugin_apps="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_apps}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_APPS], [test "${enable_plugin_apps}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# freeipmi.plugin - libipmimonitoring
|
|
|
|
PKG_CHECK_MODULES(
|
|
[IPMIMONITORING],
|
|
[libipmimonitoring],
|
|
[AC_CHECK_LIB([ipmimonitoring], [
|
|
ipmi_monitoring_sensor_readings_by_record_id,
|
|
ipmi_monitoring_sensor_readings_by_sensor_type,
|
|
ipmi_monitoring_sensor_read_sensor_number,
|
|
ipmi_monitoring_sensor_read_sensor_name,
|
|
ipmi_monitoring_sensor_read_sensor_state,
|
|
ipmi_monitoring_sensor_read_sensor_units,
|
|
ipmi_monitoring_sensor_iterator_next,
|
|
ipmi_monitoring_ctx_sensor_config_file,
|
|
ipmi_monitoring_ctx_sdr_cache_directory,
|
|
ipmi_monitoring_ctx_errormsg,
|
|
ipmi_monitoring_ctx_create
|
|
],
|
|
[AC_CHECK_HEADER(
|
|
[ipmi_monitoring.h],
|
|
[AC_CHECK_HEADER(
|
|
[ipmi_monitoring_bitmasks.h],
|
|
[have_ipmimonitoring=yes],
|
|
[have_ipmimonitoring=no]
|
|
)],
|
|
[have_ipmimonitoring=no]
|
|
)],
|
|
[have_ipmimonitoring=no]
|
|
)],
|
|
[have_ipmimonitoring=no]
|
|
)
|
|
test "${enable_plugin_freeipmi}" = "yes" -a "${have_ipmimonitoring}" != "yes" && \
|
|
AC_MSG_ERROR([ipmimonitoring required but not found. Try installing 'libipmimonitoring-dev' or 'libipmimonitoring-devel'])
|
|
|
|
AC_MSG_CHECKING([if freeipmi.plugin should be enabled])
|
|
if test "${enable_plugin_freeipmi}" != "no" -a "${have_ipmimonitoring}" = "yes"; then
|
|
enable_plugin_freeipmi="yes"
|
|
AC_DEFINE([HAVE_FREEIPMI], [1], [ipmimonitoring usability])
|
|
OPTIONAL_IPMIMONITORING_CFLAGS="${IPMIMONITORING_CFLAGS}"
|
|
OPTIONAL_IPMIMONITORING_LIBS="${IPMIMONITORING_LIBS}"
|
|
else
|
|
enable_plugin_freeipmi="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_freeipmi}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_FREEIPMI], [test "${enable_plugin_freeipmi}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# systemd-journal.plugin - systemd
|
|
|
|
LIBS_BAK="${LIBS}"
|
|
|
|
AC_CHECK_LIB([systemd], [sd_journal_open], [have_systemd_libs=yes], [have_systemd_libs=no])
|
|
AC_CHECK_HEADERS([systemd/sd-journal.h], [have_systemd_journal_header=yes], [have_systemd_journal_header=no])
|
|
|
|
if test "${have_systemd_libs}" = "yes" -a "${have_systemd_journal_header}" = "yes"; then
|
|
have_systemd="yes"
|
|
else
|
|
have_systemd="no"
|
|
fi
|
|
|
|
test "${enable_plugin_systemd_journal}" = "yes" -a "${have_systemd}" != "yes" && \
|
|
AC_MSG_ERROR([systemd is required but not found. Try installing 'libsystemd-dev' or 'libsystemd-devel'])
|
|
|
|
AC_MSG_CHECKING([if systemd-journal.plugin should be enabled])
|
|
if test "${enable_plugin_systemd_journal}" != "no" -a "${have_systemd}" = "yes"; then
|
|
enable_plugin_systemd_journal="yes"
|
|
AC_DEFINE([HAVE_SYSTEMD], [1], [systemd usability])
|
|
OPTIONAL_SYSTEMD_CFLAGS="-I/usr/include"
|
|
OPTIONAL_SYSTEMD_LIBS="-lsystemd"
|
|
else
|
|
enable_plugin_systemd_journal="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_systemd_journal}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_SYSTEMD_JOURNAL], [test "${enable_plugin_systemd_journal}" = "yes"])
|
|
|
|
AC_CHECK_LIB([systemd], [sd_journal_open_files_fd], [have_sd_journal_open_files_fd=yes], [have_sd_journal_open_files_fd=no])
|
|
if test "${have_sd_journal_open_files_fd}" = "yes"; then
|
|
AC_DEFINE([HAVE_SD_JOURNAL_OPEN_FILES_FD], [1], [sd_journal_open_files_fd usability])
|
|
fi
|
|
|
|
AC_CHECK_LIB([systemd], [sd_journal_restart_fields], [have_sd_journal_restart_fields=yes], [have_sd_journal_restart_fields=no])
|
|
if test "${have_sd_journal_restart_fields}" = "yes"; then
|
|
AC_DEFINE([HAVE_SD_JOURNAL_RESTART_FIELDS], [1], [sd_journal_restart_fields usability])
|
|
fi
|
|
|
|
AC_CHECK_LIB([systemd], [sd_journal_get_seqnum], [have_sd_journal_get_seqnum=yes], [have_sd_journal_get_seqnum=no])
|
|
if test "${have_sd_journal_get_seqnum}" = "yes"; then
|
|
AC_DEFINE([HAVE_SD_JOURNAL_GET_SEQNUM], [1], [sd_journal_get_seqnum usability])
|
|
fi
|
|
|
|
AC_CHECK_LIB([systemd], [sd_bus_default_system, sd_bus_call_method, sd_bus_message_enter_container, sd_bus_message_read, sd_bus_message_exit_container],
|
|
[SYSTEMD_DBUS_FOUND=yes],
|
|
[SYSTEMD_DBUS_FOUND=no])
|
|
|
|
if test "x$SYSTEMD_DBUS_FOUND" = "xyes"; then
|
|
AC_DEFINE([ENABLE_SYSTEMD_DBUS], [1], [libsystemd dbus usability])
|
|
fi
|
|
|
|
AC_MSG_NOTICE([OPTIONAL_SYSTEMD_LIBS is set to: ${OPTIONAL_SYSTEMD_LIBS}])
|
|
|
|
if test "${enable_plugin_systemd_journal}" = "yes"; then
|
|
AC_MSG_CHECKING([for SD_JOURNAL_OS_ROOT in systemd])
|
|
AC_COMPILE_IFELSE(
|
|
[AC_LANG_PROGRAM(
|
|
[[#include <systemd/sd-journal.h>]],
|
|
[[int x = SD_JOURNAL_OS_ROOT;]]
|
|
)],
|
|
[AC_DEFINE(HAVE_SD_JOURNAL_OS_ROOT, 1, [Define if SD_JOURNAL_OS_ROOT is available])
|
|
AC_MSG_RESULT(yes)],
|
|
[AC_MSG_RESULT(no)]
|
|
)
|
|
fi
|
|
|
|
LIBS="${LIBS_BAK}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# cups.plugin - libcups
|
|
|
|
# Only check most recently added method of cups
|
|
AC_CHECK_LIB([cups], [httpConnect2],
|
|
[AC_CHECK_HEADER(
|
|
[cups/cups.h],
|
|
[have_cups=yes],
|
|
[have_cups=no]
|
|
)],
|
|
[have_cups=no]
|
|
)
|
|
|
|
test "${enable_plugin_cups}" = "yes" -a "${have_cups}" != "yes" && \
|
|
AC_MSG_ERROR([cups required but not found. Try installing 'cups'])
|
|
|
|
AC_ARG_WITH([cups-config],
|
|
[AS_HELP_STRING([--with-cups-config=path], [Specify path to cups-config executable.])],
|
|
[with_cups_config="$withval"],
|
|
[with_cups_config=system]
|
|
)
|
|
|
|
AS_IF([test "x$with_cups_config" != "xsystem"], [
|
|
CUPSCONFIG=$with_cups_config
|
|
], [
|
|
AC_PATH_TOOL(CUPSCONFIG, [cups-config])
|
|
AS_IF([test -z "$CUPSCONFIG"], [
|
|
have_cups=no
|
|
])
|
|
])
|
|
|
|
AC_MSG_CHECKING([if cups.plugin should be enabled])
|
|
if test "${enable_plugin_cups}" != "no" -a "${have_cups}" = "yes"; then
|
|
enable_plugin_cups="yes"
|
|
AC_DEFINE([HAVE_CUPS], [1], [cups usability])
|
|
|
|
CUPS_CFLAGS="${CUPS_CFLAGS} `$CUPSCONFIG --cflags`"
|
|
CUPS_LIBS="${CUPS_LIBS} `$CUPSCONFIG --libs`"
|
|
|
|
OPTIONAL_CUPS_CFLAGS="${CUPS_CFLAGS}"
|
|
OPTIONAL_CUPS_LIBS="${CUPS_LIBS}"
|
|
else
|
|
enable_plugin_cups="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_cups}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_CUPS], [test "${enable_plugin_cups}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# nfacct.plugin - libmnl, libnetfilter_acct
|
|
|
|
AC_CHECK_HEADER(
|
|
[linux/netfilter/nfnetlink_conntrack.h],
|
|
[AC_CHECK_DECL(
|
|
[CTA_STATS_MAX],
|
|
[have_nfnetlink_conntrack=yes],
|
|
[have_nfnetlink_conntrack=no],
|
|
[#include <linux/netfilter/nfnetlink_conntrack.h>]
|
|
)],
|
|
[have_nfnetlink_conntrack=no]
|
|
)
|
|
|
|
LIBS_BAK="${LIBS}"
|
|
LIBS="${LIBS} -lmnl"
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBMNL],
|
|
[libmnl],
|
|
[AC_CHECK_LIB(
|
|
[mnl],
|
|
[mnl_socket_open],
|
|
[have_libmnl=yes],
|
|
[have_libmnl=no]
|
|
)],
|
|
[have_libmnl=no]
|
|
)
|
|
|
|
LIBS="${LIBS}"
|
|
|
|
PKG_CHECK_MODULES(
|
|
[NFACCT],
|
|
[libnetfilter_acct],
|
|
AC_SEARCH_LIBS(
|
|
[nfacct_alloc],
|
|
[netfilter_acct libnetfilter_acct],
|
|
[have_libnetfilter_acct=yes],
|
|
[have_libnetfilter_acct=no],
|
|
[${LIBS} -L/libnetfilter-acct-static/lib/libnetfilter_acct.a]
|
|
)],
|
|
[have_libnetfilter_acct=no]
|
|
)
|
|
|
|
LIBS="${LIBS_BAK}"
|
|
|
|
test "${enable_plugin_nfacct}" = "yes" -a "${have_nfnetlink_conntrack}" != "yes" && \
|
|
AC_MSG_ERROR([nfnetlink_conntrack.h required but not found or too old])
|
|
|
|
test "${enable_plugin_nfacct}" = "yes" -a "${have_libnetfilter_acct}" != "yes" && \
|
|
AC_MSG_ERROR([netfilter_acct required but not found])
|
|
|
|
test "${enable_plugin_nfacct}" = "yes" -a "${have_libmnl}" != "yes" && \
|
|
AC_MSG_ERROR([libmnl required but not found. Try installing 'libmnl-dev' or 'libmnl-devel'])
|
|
|
|
AC_MSG_CHECKING([if nfacct.plugin should be enabled])
|
|
if test "${enable_plugin_nfacct}" != "no" -a "${have_libnetfilter_acct}" = "yes" \
|
|
-a "${have_libmnl}" = "yes" \
|
|
-a "${have_nfnetlink_conntrack}" = "yes"; then
|
|
enable_plugin_nfacct="yes"
|
|
AC_DEFINE([HAVE_NFACCT], [1], [netfilter accounting usability])
|
|
OPTIONAL_NFACCT_CFLAGS="${NFACCT_CFLAGS} ${LIBMNL_CFLAGS}"
|
|
OPTIONAL_NFACCT_LIBS="${NFACCT_LIBS} ${LIBMNL_LIBS}"
|
|
else
|
|
enable_plugin_nfacct="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_nfacct}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_NFACCT], [test "${enable_plugin_nfacct}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# xenstat.plugin - libxenstat
|
|
|
|
PKG_CHECK_MODULES(
|
|
[YAJL],
|
|
[yajl],
|
|
[AC_CHECK_LIB(
|
|
[yajl],
|
|
[yajl_tree_get],
|
|
[have_libyajl=yes],
|
|
[have_libyajl=no]
|
|
)],
|
|
[have_libyajl=no]
|
|
)
|
|
|
|
AC_CHECK_LIB(
|
|
[xenstat],
|
|
[xenstat_init],
|
|
[AC_CHECK_HEADER(
|
|
[xenstat.h],
|
|
[have_libxenstat=yes],
|
|
[have_libxenstat=no]
|
|
)],
|
|
[have_libxenstat=no],
|
|
[-lyajl]
|
|
)
|
|
|
|
PKG_CHECK_MODULES(
|
|
[XENLIGHT],
|
|
[xenlight],
|
|
[AC_CHECK_LIB(
|
|
[xenlight],
|
|
[libxl_domain_info],
|
|
[AC_CHECK_HEADER(
|
|
[libxl.h],
|
|
[have_libxenlight=yes],
|
|
[have_libxenlight=no]
|
|
)],
|
|
[have_libxenlight=no]
|
|
)],
|
|
[have_libxenlight=no]
|
|
)
|
|
|
|
test "${enable_plugin_xenstat}" = "yes" -a "${have_libxenstat}" != "yes" && \
|
|
AC_MSG_ERROR([libxenstat required but not found. try installing 'xen-dom0-libs-devel'])
|
|
|
|
test "${enable_plugin_xenstat}" = "yes" -a "${have_libxenlight}" != "yes" && \
|
|
AC_MSG_ERROR([libxenlight required but not found. try installing 'xen-dom0-libs-devel'])
|
|
|
|
test "${enable_plugin_xenstat}" = "yes" -a "${have_libyajl}" != "yes" && \
|
|
AC_MSG_ERROR([libyajl required but not found. Try installing 'yajl-devel'])
|
|
|
|
AC_MSG_CHECKING([if xenstat.plugin should be enabled])
|
|
if test "${enable_plugin_xenstat}" != "no" -a "${have_libxenstat}" = "yes" -a "${have_libxenlight}" = "yes" -a "${have_libyajl}" = "yes"; then
|
|
enable_plugin_xenstat="yes"
|
|
AC_DEFINE([HAVE_LIBXENSTAT], [1], [libxenstat usability])
|
|
OPTIONAL_XENSTAT_CFLAGS="${XENLIGHT_CFLAGS} ${YAJL_CFLAGS}"
|
|
OPTIONAL_XENSTAT_LIBS="-lxenstat ${XENLIGHT_LIBS} ${YAJL_LIBS}"
|
|
else
|
|
enable_plugin_xenstat="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_xenstat}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_XENSTAT], [test "${enable_plugin_xenstat}" = "yes"])
|
|
|
|
if test "${enable_plugin_xenstat}" == "yes"; then
|
|
AC_MSG_CHECKING([for xenstat_vbd_error in -lxenstat])
|
|
AC_TRY_LINK(
|
|
[ #include <xenstat.h> ],
|
|
[
|
|
xenstat_vbd * vbd;
|
|
int out = xenstat_vbd_error(vbd);
|
|
],
|
|
[
|
|
have_xenstat_vbd_error=yes
|
|
AC_DEFINE([HAVE_XENSTAT_VBD_ERROR], [1], [xenstat_vbd_error usability])
|
|
],
|
|
[ have_xenstat_vbd_error=no ]
|
|
)
|
|
AC_MSG_RESULT([${have_xenstat_vbd_error}])
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# perf.plugin
|
|
|
|
AC_CHECK_HEADER(
|
|
[linux/perf_event.h],
|
|
[AC_CHECK_DECL(
|
|
[PERF_COUNT_HW_REF_CPU_CYCLES],
|
|
[have_perf_event=yes],
|
|
[have_perf_event=no],
|
|
[#include <linux/perf_event.h>]
|
|
)],
|
|
[have_perf_event=no]
|
|
)
|
|
|
|
AC_MSG_CHECKING([if perf.plugin should be enabled])
|
|
if test "${build_target}" == "linux" -a "${have_perf_event}" = "yes"; then
|
|
AC_DEFINE([ENABLE_PERF_PLUGIN], [1], [perf.plugin])
|
|
enable_plugin_perf="yes"
|
|
else
|
|
enable_plugin_perf="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_perf}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_PERF], [test "${enable_plugin_perf}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# gtest/gmock
|
|
|
|
if test "${enable_gtests}" = "yes"; then
|
|
AC_MSG_CHECKING([if gtest can be found])
|
|
|
|
PKG_CHECK_MODULES([GTEST], [gtest], [have_gtest=yes], [have_gtest=no])
|
|
|
|
if test "${have_gtest}" = "yes"; then
|
|
OPTIONAL_GTEST_CFLAGS="${GTEST_CFLAGS}"
|
|
OPTIONAL_GTEST_LIBS="${GTEST_LIBS}"
|
|
|
|
AC_DEFINE([HAVE_GTEST], [1], [gtest availability])
|
|
fi
|
|
fi
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# ml - anomaly detection
|
|
|
|
# Check if uuid is available. Fail if ML was explicitly requested.
|
|
if test "${enable_ml}" = "yes" -a "${have_uuid}" != "yes"; then
|
|
AC_MSG_ERROR([You have explicitly requested --enable-ml functionality but libuuid can not be found.])
|
|
fi
|
|
|
|
# Check if submodules have not been fetched. Fail if ML was explicitly requested.
|
|
AC_MSG_CHECKING([if git submodules are present for machine learning functionality])
|
|
if test -f "ml/dlib/dlib/all/source.cpp"; then
|
|
AC_MSG_RESULT([yes])
|
|
have_ml_submodules="yes"
|
|
AC_DEFINE([HAVE_DLIB], [1], [dlib availability])
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
have_ml_submodules="no"
|
|
fi
|
|
|
|
if test "${enable_ml}" = "yes" -a "${have_ml_submodules}" = "no"; then
|
|
AC_MSG_ERROR([You have explicitly requested --enable-ml functionality but it cannot be built because the required git submodules are missing.])
|
|
fi
|
|
|
|
if test "${enable_ml}" = "yes" -a "${have_cxx11}" = "no"; then
|
|
AC_MSG_ERROR([You have explicitly requested --enable-ml functionality but it cannot be built without a C++11 toolchain.])
|
|
fi
|
|
|
|
# Decide if we should build ML
|
|
if test "${enable_ml}" != "no" -a "${have_ml_submodules}" = "yes" -a "${have_cxx11}" = "yes" -a "${have_uuid}" = "yes"; then
|
|
build_ml="yes"
|
|
else
|
|
build_ml="no"
|
|
fi
|
|
|
|
AM_CONDITIONAL([ENABLE_ML], [test "${build_ml}" = "yes"])
|
|
if test "${build_ml}" = "yes"; then
|
|
AC_DEFINE([ENABLE_ML], [1], [anomaly detection usability])
|
|
OPTIONAL_ML_CFLAGS="-DDLIB_NO_GUI_SUPPORT -I \$(abs_top_srcdir)/ml/dlib"
|
|
OPTIONAL_ML_LIBS=""
|
|
fi
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# logsmanagement
|
|
|
|
LIBS_BAK="${LIBS}"
|
|
|
|
# Check if submodules have not been fetched. Fail if Logs Management was explicitly requested.
|
|
|
|
AC_MSG_CHECKING([if git submodules are present for logs management functionality])
|
|
if test -f "fluent-bit/CMakeLists.txt"; then
|
|
AC_MSG_RESULT([yes])
|
|
have_logsmanagement_submodules="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
have_logsmanagement_submodules="no"
|
|
fi
|
|
|
|
if test "${enable_logsmanagement}" != "no" -a "${have_logsmanagement_submodules}" = "no"; then
|
|
AC_MSG_WARN([Logs management cannot be built because the required git submodules are missing.])
|
|
fi
|
|
|
|
if test "${enable_logsmanagement}" != "no" -a "x$CAN_USE_DLSYM" = xno; then
|
|
AC_MSG_WARN([Logs management cannot be built because dlsym cannot be used.])
|
|
fi
|
|
|
|
# Decide if we should build Logs Management
|
|
if test "${enable_logsmanagement}" != "no" -a "${have_logsmanagement_submodules}" = "yes" -a "x$CAN_USE_DLSYM" = xyes; then
|
|
build_logsmanagement="yes"
|
|
else
|
|
build_logsmanagement="no"
|
|
fi
|
|
|
|
AM_CONDITIONAL([ENABLE_LOGSMANAGEMENT], [test "${build_logsmanagement}" = "yes"])
|
|
if test "${build_logsmanagement}" = "yes"; then
|
|
AC_DEFINE([ENABLE_LOGSMANAGEMENT], [1], [enable logs management functionality])
|
|
fi
|
|
|
|
# Decide if we should build Logs Management tests.
|
|
if test "${build_logsmanagement}" = "yes" -a "${enable_logsmanagement_tests}" = "yes"; then
|
|
build_logsmanagement_tests="yes"
|
|
else
|
|
build_logsmanagement_tests="no"
|
|
fi
|
|
|
|
AM_CONDITIONAL([ENABLE_LOGSMANAGEMENT_TESTS], [test "${build_logsmanagement_tests}" = "yes"])
|
|
if test "${build_logsmanagement_tests}" = "yes"; then
|
|
AC_DEFINE([ENABLE_LOGSMANAGEMENT_TESTS], [1], [logs management tests])
|
|
fi
|
|
|
|
LIBS="${LIBS_BAK}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# debugfs.plugin
|
|
|
|
if test "${build_target}" = "linux"; then
|
|
AC_DEFINE([ENABLE_DEBUGFS_PLUGIN], [1], [debugfs.plugin])
|
|
enable_plugin_debugfs="yes"
|
|
else
|
|
enable_plugin_debugfs="no"
|
|
fi
|
|
|
|
AC_MSG_CHECKING([if debugfs.plugin should be enabled])
|
|
AC_MSG_RESULT([${enable_plugin_debugfs}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_DEBUGFS], [test "${enable_plugin_debugfs}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# ebpf.plugin
|
|
|
|
if test "${build_target}" = "linux" -a "${enable_ebpf}" != "no"; then
|
|
PKG_CHECK_MODULES(
|
|
[LIBELF],
|
|
[libelf],
|
|
[have_libelf=yes],
|
|
[have_libelf=no]
|
|
)
|
|
|
|
AC_CHECK_TYPE(
|
|
[struct bpf_prog_info],
|
|
[have_bpf=yes],
|
|
[have_bpf=no],
|
|
[#include <linux/bpf.h>]
|
|
)
|
|
|
|
AC_CHECK_FILE(
|
|
externaldeps/libbpf/libbpf.a,
|
|
[have_libbpf=yes],
|
|
[have_libbpf=no]
|
|
)
|
|
|
|
if test "${have_libelf}" = "yes" -a \
|
|
"${have_bpf}" = "yes" -a \
|
|
"${have_libbpf}" = "yes"; then
|
|
OPTIONAL_BPF_CFLAGS="${LIBELF_CFLAGS} -I \$(abs_top_srcdir)/externaldeps/libbpf/include -I \$(abs_top_srcdir)/externaldeps/libbpf/include/uapi"
|
|
OPTIONAL_BPF_LIBS="\$(abs_top_srcdir)/externaldeps/libbpf/libbpf.a ${LIBELF_LIBS}"
|
|
AC_DEFINE([HAVE_LIBBPF], [1], [libbpf usability])
|
|
enable_ebpf="yes"
|
|
else
|
|
enable_ebpf="no"
|
|
fi
|
|
else
|
|
enable_ebpf="no"
|
|
fi
|
|
AC_MSG_CHECKING([if ebpf.plugin should be enabled])
|
|
AC_MSG_RESULT([${enable_ebpf}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_EBPF], [test "${enable_ebpf}" = "yes"])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# slabinfo.plugin
|
|
|
|
AC_MSG_CHECKING([if slabinfo.plugin should be enabled])
|
|
if test "${build_target}" == "linux"; then
|
|
AC_DEFINE([ENABLE_SLABINFO], [1], [slabinfo plugin])
|
|
enable_plugin_slabinfo="yes"
|
|
else
|
|
enable_plugin_slabinfo="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_plugin_slabinfo}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_SLABINFO], [test "${enable_plugin_slabinfo}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# AWS Kinesis exporting connector - libaws-cpp-sdk-kinesis, libaws-cpp-sdk-core, libssl, libcrypto, libcurl
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBCRYPTO],
|
|
[libcrypto],
|
|
[AC_CHECK_LIB(
|
|
[crypto],
|
|
[CRYPTO_new_ex_data],
|
|
[have_libcrypto=yes],
|
|
[have_libcrypto=no]
|
|
)],
|
|
[have_libcrypto=no]
|
|
)
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBSSL],
|
|
[libssl],
|
|
[AC_CHECK_LIB(
|
|
[ssl],
|
|
[SSL_connect],
|
|
[have_libssl=yes],
|
|
[have_libssl=no]
|
|
)],
|
|
[have_libssl=no]
|
|
)
|
|
|
|
PKG_CHECK_MODULES(
|
|
[AWS_CPP_SDK_CORE],
|
|
[aws-cpp-sdk-core],
|
|
[have_libaws_cpp_sdk_core=yes],
|
|
[have_libaws_cpp_sdk_core=no]
|
|
)
|
|
|
|
PKG_CHECK_MODULES(
|
|
[AWS_CPP_SDK_KINESIS],
|
|
[aws-cpp-sdk-kinesis],
|
|
[have_libaws_cpp_sdk_kinesis=yes],
|
|
[have_libaws_cpp_sdk_kinesis=no]
|
|
)
|
|
|
|
test "${enable_exporting_kinesis}" = "yes" -a "${have_libaws_cpp_sdk_kinesis}" != "yes" && \
|
|
AC_MSG_ERROR([libaws-cpp-sdk-kinesis required but not found. try installing AWS C++ SDK])
|
|
|
|
test "${enable_exporting_kinesis}" = "yes" -a "${have_libaws_cpp_sdk_core}" != "yes" && \
|
|
AC_MSG_ERROR([libaws-cpp-sdk-core required but not found. try installing AWS C++ SDK])
|
|
|
|
test "${enable_exporting_kinesis}" = "yes" -a "${have_libcurl}" != "yes" && \
|
|
AC_MSG_ERROR([libcurl required but not found])
|
|
|
|
test "${enable_exporting_kinesis}" = "yes" -a "${have_libssl}" != "yes" && \
|
|
AC_MSG_ERROR([libssl required but not found])
|
|
|
|
test "${enable_exporting_kinesis}" = "yes" -a "${have_libcrypto}" != "yes" && \
|
|
AC_MSG_ERROR([libcrypto required but not found])
|
|
|
|
AC_MSG_CHECKING([if kinesis exporting connector should be enabled])
|
|
if test "${enable_exporting_kinesis}" != "no" -a "${have_libaws_cpp_sdk_kinesis}" = "yes" \
|
|
-a "${have_libaws_cpp_sdk_core}" = "yes" \
|
|
-a "${have_libcurl}" = "yes" \
|
|
-a "${have_libssl}" = "yes" \
|
|
-a "${have_libcrypto}" = "yes"; then
|
|
enable_exporting_kinesis="yes"
|
|
AC_DEFINE([HAVE_KINESIS], [1], [libaws-cpp-sdk-kinesis usability])
|
|
OPTIONAL_KINESIS_CFLAGS="${LIBCRYPTO_CFLAGS} ${LIBSSL_CFLAGS} ${LIBCURL_CFLAGS}"
|
|
OPTIONAL_KINESIS_CXXFLAGS="${AWS_CPP_SDK_KINESIS_CFLAGS} ${AWS_CPP_SDK_CORE_CFLAGS}"
|
|
OPTIONAL_KINESIS_LIBS="${AWS_CPP_SDK_KINESIS_LIBS} ${AWS_CPP_SDK_CORE_LIBS} \
|
|
${LIBCRYPTO_LIBS} ${LIBSSL_LIBS} ${LIBCURL_LIBS}"
|
|
else
|
|
enable_exporting_kinesis="no"
|
|
fi
|
|
|
|
AC_MSG_RESULT([${enable_exporting_kinesis}])
|
|
AM_CONDITIONAL([ENABLE_EXPORTING_KINESIS], [test "${enable_exporting_kinesis}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Pub/Sub exporting connector - googleapis
|
|
|
|
PKG_CHECK_MODULES(
|
|
[GRPC],
|
|
[grpc],
|
|
[have_libgrpc=yes],
|
|
[have_libgrpc=no]
|
|
)
|
|
|
|
if test "${enable_exporting_pubsub}" != "no"; then
|
|
PKG_CHECK_MODULES(
|
|
[PUBSUB],
|
|
[google_cloud_cpp_pubsub_protos],
|
|
[have_pubsub_protos=yes],
|
|
[have_pubsub_protos=no]
|
|
)
|
|
fi
|
|
|
|
AC_PATH_PROG([CXX_BINARY], [${CXX}], [no])
|
|
AS_IF(
|
|
[test x"${CXX_BINARY}" == x"no"],
|
|
[have_CXX_compiler=no],
|
|
[have_CXX_compiler=yes]
|
|
)
|
|
|
|
test "${enable_pubsub}" = "yes" -a "${have_grpc}" != "yes" && \
|
|
AC_MSG_ERROR([libgrpc required but not found. try installing grpc])
|
|
|
|
test "${enable_pubsub}" = "yes" -a "${have_pubsub_protos}" != "yes" && \
|
|
AC_MSG_ERROR([libgoogleapis_cpp_pubsub_protos required but not found. try installing googleapis])
|
|
|
|
test "${enable_exporting_prometheus_remote_write}" = "yes" -a "${have_CXX_compiler}" != "yes" && \
|
|
AC_MSG_ERROR([C++ compiler required but not found. try installing g++])
|
|
|
|
AC_MSG_CHECKING([if pubsub exporting connector should be enabled])
|
|
if test "${enable_exporting_pubsub}" != "no" -a "${have_pubsub_protos}" = "yes" -a "${have_CXX_compiler}" = "yes"; then
|
|
enable_exporting_pubsub="yes"
|
|
AC_DEFINE([ENABLE_EXPORTING_PUBSUB], [1], [Pub/Sub API usability])
|
|
OPTIONAL_PUBSUB_CFLAGS="${GRPC_CFLAGS} ${PUBSUB_CFLAGS}"
|
|
OPTIONAL_PUBSUB_LIBS="${GRPC_LIBS} ${PUBSUB_LIBS}"
|
|
else
|
|
enable_pubsub="no"
|
|
fi
|
|
|
|
AC_MSG_RESULT([${enable_exporting_pubsub}])
|
|
AM_CONDITIONAL([ENABLE_EXPORTING_PUBSUB], [test "${enable_exporting_pubsub}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Prometheus remote write exporting connector - libprotobuf, libsnappy, protoc
|
|
|
|
AC_MSG_CHECKING([for snappy::RawCompress in -lsnappy])
|
|
|
|
AC_LANG_SAVE
|
|
AC_LANG_CPLUSPLUS
|
|
save_LIBS="${LIBS}"
|
|
LIBS="-lsnappy"
|
|
save_CXXFLAGS="${CXXFLAGS}"
|
|
CXXFLAGS="${CXXFLAGS} ${CPP_STD_FLAG}"
|
|
|
|
AC_TRY_LINK(
|
|
[
|
|
#include <stdlib.h>
|
|
#include <snappy.h>
|
|
],
|
|
[
|
|
const char *input = "test";
|
|
size_t compressed_length;
|
|
char *buffer = (char *)malloc(5 * sizeof(char));
|
|
snappy::RawCompress(input, 4, buffer, &compressed_length);
|
|
free(buffer);
|
|
],
|
|
[
|
|
have_libsnappy=yes
|
|
SNAPPY_CFLAGS=""
|
|
SNAPPY_LIBS="-lsnappy"
|
|
],
|
|
[have_libsnappy=no]
|
|
)
|
|
|
|
LIBS="${save_LIBS}"
|
|
CXXFLAGS="${save_CXXFLAGS}"
|
|
AC_LANG_RESTORE
|
|
|
|
AC_MSG_RESULT([${have_libsnappy}])
|
|
|
|
test "${enable_exporting_prometheus_remote_write}" = "yes" -a "${have_libprotobuf}" != "yes" && \
|
|
AC_MSG_ERROR([libprotobuf required but not found. try installing protobuf])
|
|
|
|
test "${enable_exporting_prometheus_remote_write}" = "yes" -a "${have_libsnappy}" != "yes" && \
|
|
AC_MSG_ERROR([libsnappy required but not found. try installing snappy])
|
|
|
|
test "${enable_exporting_prometheus_remote_write}" = "yes" -a "${have_protoc}" != "yes" && \
|
|
AC_MSG_ERROR([protoc compiler required but not found. try installing protobuf])
|
|
|
|
test "${enable_exporting_prometheus_remote_write}" = "yes" -a "${have_CXX_compiler}" != "yes" && \
|
|
AC_MSG_ERROR([C++ compiler required but not found. try installing g++])
|
|
|
|
AC_MSG_CHECKING([if prometheus remote write exporting connector should be enabled])
|
|
if test "${enable_exporting_prometheus_remote_write}" != "no" -a "${have_libprotobuf}" = "yes" -a "${have_libsnappy}" = "yes" \
|
|
-a "${have_protoc}" = "yes" -a "${have_CXX_compiler}" = "yes"; then
|
|
enable_exporting_prometheus_remote_write="yes"
|
|
AC_DEFINE([ENABLE_PROMETHEUS_REMOTE_WRITE], [1], [Prometheus remote write API usability])
|
|
OPTIONAL_PROMETHEUS_REMOTE_WRITE_CFLAGS="${SNAPPY_CFLAGS} -I \$(abs_top_srcdir)/exporting/prometheus/remote_write"
|
|
OPTIONAL_PROMETHEUS_REMOTE_WRITE_LIBS="${SNAPPY_LIBS}"
|
|
OPTIONAL_PROTOBUF_CFLAGS="${PROTOBUF_CFLAGS}"
|
|
OPTIONAL_PROTOBUF_LIBS="${PROTOBUF_LIBS}"
|
|
else
|
|
enable_exporting_prometheus_remote_write="no"
|
|
fi
|
|
|
|
AC_MSG_RESULT([${enable_exporting_prometheus_remote_write}])
|
|
AM_CONDITIONAL([ENABLE_EXPORTING_PROMETHEUS_REMOTE_WRITE], [test "${enable_exporting_prometheus_remote_write}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# MongoDB exporting connector - libmongoc
|
|
|
|
PKG_CHECK_MODULES(
|
|
[LIBMONGOC],
|
|
[libmongoc-1.0 >= 1.7],
|
|
[have_libmongoc=yes],
|
|
[have_libmongoc=no]
|
|
)
|
|
|
|
test "${enable_exporting_mongodb}" = "yes" -a "${have_libmongoc}" != "yes" && \
|
|
AC_MSG_ERROR([libmongoc required but not found. Try installing `mongoc`.])
|
|
|
|
AC_MSG_CHECKING([if mongodb exporting connector should be enabled])
|
|
if test "${enable_exporting_mongodb}" != "no" -a "${have_libmongoc}" = "yes"; then
|
|
enable_exporting_mongodb="yes"
|
|
AC_DEFINE([HAVE_MONGOC], [1], [libmongoc usability])
|
|
OPTIONAL_MONGOC_CFLAGS="${LIBMONGOC_CFLAGS}"
|
|
OPTIONAL_MONGOC_LIBS="${LIBMONGOC_LIBS}"
|
|
else
|
|
enable_exporting_mongodb="no"
|
|
fi
|
|
|
|
AC_MSG_RESULT([${enable_exporting_mongodb}])
|
|
AM_CONDITIONAL([ENABLE_EXPORTING_MONGODB], [test "${enable_exporting_mongodb}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# check for setns() - cgroup-network
|
|
|
|
AC_CHECK_FUNC([setns])
|
|
AC_MSG_CHECKING([if cgroup-network can be enabled])
|
|
if test "$ac_cv_func_setns" = "yes" ; then
|
|
have_setns="yes"
|
|
AC_DEFINE([HAVE_SETNS], [1], [Define 1 if you have setns() function])
|
|
else
|
|
have_setns="no"
|
|
fi
|
|
AC_MSG_RESULT([${have_setns}])
|
|
AM_CONDITIONAL([ENABLE_PLUGIN_CGROUP_NETWORK], [test "${have_setns}" = "yes"])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Link-Time-Optimization
|
|
|
|
if test "${enable_lto}" != "no"; then
|
|
opt="-flto"
|
|
AX_CHECK_COMPILE_FLAG(${opt}, [have_lto=yes], [have_lto=no])
|
|
fi
|
|
if test "${have_lto}" = "yes"; then
|
|
oCFLAGS="${CFLAGS}"
|
|
CFLAGS="${CFLAGS} -flto"
|
|
ac_cv_c_lto_cross_compile="${enable_lto}"
|
|
test "${ac_cv_c_lto_cross_compile}" != "yes" && ac_cv_c_lto_cross_compile="no"
|
|
AC_C_LTO
|
|
CFLAGS="${oCFLAGS}"
|
|
test "${ac_cv_c_lto}" != "yes" && have_lto="no"
|
|
fi
|
|
test "${enable_lto}" = "yes" -a "${have_lto}" != "yes" && \
|
|
AC_MSG_ERROR([LTO is required but is not available.])
|
|
AC_MSG_CHECKING([if LTO should be enabled])
|
|
if test "${enable_lto}" != "no" -a "${have_lto}" = "yes"; then
|
|
enable_lto="yes"
|
|
OPTIONAL_LTO_CFLAGS="-flto"
|
|
else
|
|
enable_lto="no"
|
|
fi
|
|
AC_MSG_RESULT([${enable_lto}])
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
# Try to unconditionally link with -latomic. If the compiler can satisfy
|
|
# all the atomic ops with builtins then, the library will be left unused.
|
|
# Otherwise, some ops will be covered by the compiler's intrinsics and some
|
|
# will be picked up by the linker from -latomic. In the later case, if
|
|
# -latomic is not available there will be a build failure, which would
|
|
# have happened either way before this change.
|
|
AC_LANG_PUSH([C++])
|
|
|
|
AC_MSG_CHECKING(whether we can use -latomic)
|
|
OLD_LIBS="${LIBS}"
|
|
LIBS="-latomic"
|
|
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
#include <atomic>
|
|
#include <cstdint>
|
|
std::atomic<std::int64_t> v;
|
|
int main() {
|
|
return v;
|
|
}
|
|
]])], CAN_USE_LIBATOMIC=yes, CAN_USE_LIBATOMIC=no)
|
|
LIBS="${OLD_LIBS}"
|
|
AC_MSG_RESULT($CAN_USE_LIBATOMIC)
|
|
|
|
if test "x$CAN_USE_LIBATOMIC" = xyes; then
|
|
OPTIONAL_ATOMIC_LIBS="-latomic"
|
|
fi
|
|
AC_SUBST([OPTIONAL_ATOMIC_LIBS])
|
|
|
|
AC_LANG_POP([C++])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
|
|
AC_DEFINE_UNQUOTED([NETDATA_USER], ["${with_user}"], [use this user to drop privileged])
|
|
|
|
varlibdir="${localstatedir}/lib/netdata"
|
|
registrydir="${localstatedir}/lib/netdata/registry"
|
|
cachedir="${localstatedir}/cache/netdata"
|
|
chartsdir="${libexecdir}/netdata/charts.d"
|
|
pythondir="${libexecdir}/netdata/python.d"
|
|
configdir="${sysconfdir}/netdata"
|
|
libconfigdir="${libdir}/netdata/conf.d"
|
|
logdir="${localstatedir}/log/netdata"
|
|
pluginsdir="${libexecdir}/netdata/plugins.d"
|
|
netdata_user="${with_user}"
|
|
libsysdir="${libdir}/netdata/system"
|
|
|
|
AC_SUBST([varlibdir])
|
|
AC_SUBST([registrydir])
|
|
AC_SUBST([cachedir])
|
|
AC_SUBST([chartsdir])
|
|
AC_SUBST([pythondir])
|
|
AC_SUBST([configdir])
|
|
AC_SUBST([libconfigdir])
|
|
AC_SUBST([logdir])
|
|
AC_SUBST([pluginsdir])
|
|
AC_SUBST([webdir])
|
|
AC_SUBST([netdata_user])
|
|
AC_SUBST([libsysdir])
|
|
|
|
CFLAGS="${originalCFLAGS} ${OPTIONAL_LTO_CFLAGS} ${OPTIONAL_PROTOBUF_CFLAGS} ${OPTIONAL_MATH_CFLAGS} ${OPTIONAL_NFACCT_CFLAGS} \
|
|
${ZLIB_CFLAGS} ${OPTIONAL_UUID_CFLAGS} \
|
|
${OPTIONAL_LIBCAP_CFLAGS} ${OPTIONAL_IPMIMONITORING_CFLAGS} ${OPTIONAL_CUPS_CFLAGS} ${OPTIONAL_XENSTAT_FLAGS} \
|
|
${OPTIONAL_KINESIS_CFLAGS} ${OPTIONAL_PUBSUB_CFLAGS} ${OPTIONAL_PROMETHEUS_REMOTE_WRITE_CFLAGS} \
|
|
${OPTIONAL_MONGOC_CFLAGS} ${LWS_CFLAGS} ${OPTIONAL_JSONC_STATIC_CFLAGS} ${OPTIONAL_YAML_STATIC_CFLAGS} ${OPTIONAL_BPF_CFLAGS} ${JUDY_CFLAGS} \
|
|
${OPTIONAL_ACLK_CFLAGS} ${OPTIONAL_ML_CFLAGS} ${OPTIONAL_OS_DEP_CFLAGS} ${H2O_CFLAGS} ${HARDENING_CFLAGS}"
|
|
|
|
CXXFLAGS="${CFLAGS} ${OPTIONAL_KINESIS_CXXFLAGS} ${CPP_STD_FLAG}"
|
|
|
|
CPPFLAGS="\
|
|
-DVARLIB_DIR=\"\\\"${varlibdir}\\\"\" \
|
|
-DCACHE_DIR=\"\\\"${cachedir}\\\"\" \
|
|
-DCONFIG_DIR=\"\\\"${configdir}\\\"\" \
|
|
-DLIBCONFIG_DIR=\"\\\"${libconfigdir}\\\"\" \
|
|
-DLOG_DIR=\"\\\"${logdir}\\\"\" \
|
|
-DPLUGINS_DIR=\"\\\"${pluginsdir}\\\"\" \
|
|
-DRUN_DIR=\"\\\"${localstatedir}/run/netdata\\\"\" \
|
|
-DWEB_DIR=\"\\\"${webdir}\\\"\" \
|
|
"
|
|
|
|
AC_SUBST([OPTIONAL_MATH_CFLAGS])
|
|
AC_SUBST([OPTIONAL_MATH_LIBS])
|
|
AC_SUBST([OPTIONAL_DATACHANNEL_LIBS])
|
|
AC_SUBST([OPTIONAL_UV_LIBS])
|
|
AC_SUBST([OPTIONAL_LZ4_LIBS])
|
|
AC_SUBST([OPTIONAL_BROTLIENC_LIBS])
|
|
AC_SUBST([OPTIONAL_BROTLIDEC_LIBS])
|
|
AC_SUBST([OPTIONAL_YAML_LIBS])
|
|
AC_SUBST([OPTIONAL_CURL_LIBS])
|
|
AC_SUBST([OPTIONAL_PCRE2_LIBS])
|
|
AC_SUBST([OPTIONAL_ZSTD_LIBS])
|
|
AC_SUBST([OPTIONAL_SSL_LIBS])
|
|
AC_SUBST([OPTIONAL_JSONC_LIBS])
|
|
AC_SUBST([OPTIONAL_YAML_LIBS])
|
|
AC_SUBST([OPTIONAL_NFACCT_CFLAGS])
|
|
AC_SUBST([OPTIONAL_NFACCT_LIBS])
|
|
AC_SUBST([ZLIB_CFLAGS])
|
|
AC_SUBST([ZLIB_LIBS])
|
|
AC_SUBST([OPTIONAL_UUID_CFLAGS])
|
|
AC_SUBST([OPTIONAL_UUID_LIBS])
|
|
AC_SUBST([OPTIONAL_BPF_CFLAGS])
|
|
AC_SUBST([OPTIONAL_BPF_LIBS])
|
|
AC_SUBST([OPTIONAL_MQTT_LIBS])
|
|
AC_SUBST([OPTIONAL_LIBCAP_CFLAGS])
|
|
AC_SUBST([OPTIONAL_LIBCAP_LIBS])
|
|
AC_SUBST([OPTIONAL_IPMIMONITORING_CFLAGS])
|
|
AC_SUBST([OPTIONAL_IPMIMONITORING_LIBS])
|
|
AC_SUBST([OPTIONAL_CUPS_CFLAGS])
|
|
AC_SUBST([OPTIONAL_CUPS_LIBS])
|
|
AC_SUBST([OPTIONAL_XENSTAT_CFLAGS])
|
|
AC_SUBST([OPTIONAL_XENSTAT_LIBS])
|
|
AC_SUBST([OPTIONAL_KINESIS_CFLAGS])
|
|
AC_SUBST([OPTIONAL_KINESIS_LIBS])
|
|
AC_SUBST([OPTIONAL_PUBSUB_CFLAGS])
|
|
AC_SUBST([OPTIONAL_PUBSUB_LIBS])
|
|
AC_SUBST([OPTIONAL_PROMETHEUS_REMOTE_WRITE_CFLAGS])
|
|
AC_SUBST([OPTIONAL_PROMETHEUS_REMOTE_WRITE_LIBS])
|
|
AC_SUBST([OPTIONAL_MONGOC_CFLAGS])
|
|
AC_SUBST([OPTIONAL_MONGOC_LIBS])
|
|
AC_SUBST([OPTIONAL_LWS_LIBS])
|
|
AC_SUBST([OPTIONAL_ACLK_CFLAGS])
|
|
AC_SUBST([OPTIONAL_PROTOBUF_CFLAGS])
|
|
AC_SUBST([OPTIONAL_PROTOBUF_LIBS])
|
|
AC_SUBST([OPTIONAL_GTEST_CFLAGS])
|
|
AC_SUBST([OPTIONAL_GTEST_LIBS])
|
|
AC_SUBST([OPTIONAL_ML_CFLAGS])
|
|
AC_SUBST([OPTIONAL_ML_LIBS])
|
|
AC_SUBST(OPTIONAL_SYSTEMD_LIBS)
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Check if cmocka is available - needed for unit testing
|
|
|
|
AC_ARG_ENABLE(
|
|
[unit-tests],
|
|
[AS_HELP_STRING([--disable-unit-tests],
|
|
[Disables building and running the unit tests suite])],
|
|
[],
|
|
[enable_unit_tests="yes"]
|
|
)
|
|
|
|
|
|
PKG_CHECK_MODULES(
|
|
[CMOCKA],
|
|
[cmocka],
|
|
[have_cmocka="yes"],
|
|
[AC_MSG_NOTICE([CMocka not found on the system. Unit tests disabled])]
|
|
)
|
|
AM_CONDITIONAL([ENABLE_UNITTESTS], [test "${enable_unit_tests}" = "yes" -a "${have_cmocka}" = "yes" ])
|
|
AC_SUBST([ENABLE_UNITTESTS])
|
|
|
|
TEST_CFLAGS="${CFLAGS} ${CMOCKA_CFLAGS}"
|
|
TEST_LIBS="${CMOCKA_LIBS}"
|
|
|
|
AC_SUBST([TEST_CFLAGS])
|
|
AC_SUBST([TEST_LIBS])
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# save configure options for build info
|
|
|
|
AC_DEFINE_UNQUOTED(
|
|
[CONFIGURE_COMMAND],
|
|
["$ac_configure_args"],
|
|
[options passed to configure script]
|
|
)
|
|
|
|
AC_CONFIG_FILES([
|
|
Makefile
|
|
netdata.spec
|
|
collectors/Makefile
|
|
collectors/apps.plugin/Makefile
|
|
collectors/cgroups.plugin/Makefile
|
|
collectors/charts.d.plugin/Makefile
|
|
collectors/debugfs.plugin/Makefile
|
|
collectors/diskspace.plugin/Makefile
|
|
collectors/timex.plugin/Makefile
|
|
collectors/ioping.plugin/Makefile
|
|
collectors/freebsd.plugin/Makefile
|
|
collectors/freeipmi.plugin/Makefile
|
|
collectors/cups.plugin/Makefile
|
|
collectors/idlejitter.plugin/Makefile
|
|
collectors/macos.plugin/Makefile
|
|
collectors/nfacct.plugin/Makefile
|
|
collectors/plugins.d/Makefile
|
|
collectors/proc.plugin/Makefile
|
|
collectors/python.d.plugin/Makefile
|
|
collectors/slabinfo.plugin/Makefile
|
|
collectors/statsd.plugin/Makefile
|
|
collectors/ebpf.plugin/Makefile
|
|
collectors/tc.plugin/Makefile
|
|
collectors/xenstat.plugin/Makefile
|
|
collectors/perf.plugin/Makefile
|
|
collectors/systemd-journal.plugin/Makefile
|
|
daemon/Makefile
|
|
database/Makefile
|
|
database/contexts/Makefile
|
|
database/engine/Makefile
|
|
database/ram/Makefile
|
|
database/sqlite/Makefile
|
|
diagrams/Makefile
|
|
exporting/Makefile
|
|
exporting/graphite/Makefile
|
|
exporting/json/Makefile
|
|
exporting/opentsdb/Makefile
|
|
exporting/prometheus/Makefile
|
|
exporting/prometheus/remote_write/Makefile
|
|
exporting/aws_kinesis/Makefile
|
|
exporting/pubsub/Makefile
|
|
exporting/mongodb/Makefile
|
|
exporting/tests/Makefile
|
|
health/Makefile
|
|
health/notifications/Makefile
|
|
libnetdata/Makefile
|
|
libnetdata/tests/Makefile
|
|
libnetdata/adaptive_resortable_list/Makefile
|
|
libnetdata/aral/Makefile
|
|
libnetdata/avl/Makefile
|
|
libnetdata/buffer/Makefile
|
|
libnetdata/buffered_reader/Makefile
|
|
libnetdata/clocks/Makefile
|
|
libnetdata/completion/Makefile
|
|
libnetdata/config/Makefile
|
|
libnetdata/datetime/Makefile
|
|
libnetdata/dictionary/Makefile
|
|
libnetdata/ebpf/Makefile
|
|
libnetdata/eval/Makefile
|
|
libnetdata/facets/Makefile
|
|
libnetdata/functions_evloop/Makefile
|
|
libnetdata/july/Makefile
|
|
libnetdata/line_splitter/Makefile
|
|
libnetdata/locks/Makefile
|
|
libnetdata/log/Makefile
|
|
libnetdata/onewayalloc/Makefile
|
|
libnetdata/popen/Makefile
|
|
libnetdata/procfile/Makefile
|
|
libnetdata/simple_pattern/Makefile
|
|
libnetdata/socket/Makefile
|
|
libnetdata/statistical/Makefile
|
|
libnetdata/string/Makefile
|
|
libnetdata/storage_number/Makefile
|
|
libnetdata/storage_number/tests/Makefile
|
|
libnetdata/threads/Makefile
|
|
libnetdata/url/Makefile
|
|
libnetdata/uuid/Makefile
|
|
libnetdata/json/Makefile
|
|
libnetdata/health/Makefile
|
|
libnetdata/worker_utilization/Makefile
|
|
registry/Makefile
|
|
streaming/Makefile
|
|
system/Makefile
|
|
tests/Makefile
|
|
web/Makefile
|
|
web/api/Makefile
|
|
web/api/badges/Makefile
|
|
web/api/ilove/Makefile
|
|
web/api/exporters/Makefile
|
|
web/api/exporters/shell/Makefile
|
|
web/api/exporters/prometheus/Makefile
|
|
web/api/formatters/Makefile
|
|
web/api/formatters/csv/Makefile
|
|
web/api/formatters/json/Makefile
|
|
web/api/formatters/ssv/Makefile
|
|
web/api/formatters/value/Makefile
|
|
web/api/queries/Makefile
|
|
web/api/queries/average/Makefile
|
|
web/api/queries/countif/Makefile
|
|
web/api/queries/des/Makefile
|
|
web/api/queries/incremental_sum/Makefile
|
|
web/api/queries/max/Makefile
|
|
web/api/queries/median/Makefile
|
|
web/api/queries/min/Makefile
|
|
web/api/queries/percentile/Makefile
|
|
web/api/queries/ses/Makefile
|
|
web/api/queries/stddev/Makefile
|
|
web/api/queries/sum/Makefile
|
|
web/api/queries/trimmed_mean/Makefile
|
|
web/api/health/Makefile
|
|
web/gui/Makefile
|
|
web/gui/v1/Makefile
|
|
web/gui/v2/Makefile
|
|
web/rtc/Makefile
|
|
web/server/Makefile
|
|
web/server/static/Makefile
|
|
claim/Makefile
|
|
spawn/Makefile
|
|
logsmanagement/Makefile
|
|
])
|
|
|
|
AC_OUTPUT
|
|
|
|
test "${with_math}" != "yes" && AC_MSG_WARN([You are building without math. math allows accurate calculations. It should be enabled.]) || :
|