From 0b9371dcc5d26b2721482a7c0f89eb154dbe364f Mon Sep 17 00:00:00 2001 From: Tom Tan Date: Wed, 13 Dec 2023 12:37:55 -0800 Subject: [PATCH 1/4] [BUILD] Fix removing of NOMINMAX on Windows (#2449) --- CHANGELOG.md | 3 +++ api/include/opentelemetry/std/span.h | 2 +- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6ba0da393c..e305d85948 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,6 +15,9 @@ Increment the: ## [Unreleased] +* [BUILD] Fix removing of NOMINMAX on Windows + [#2449](https://github.com/open-telemetry/opentelemetry-cpp/pull/2449) + ## [1.13.0] 2023-12-06 * [BUILD] Remove WITH_REMOVE_METER_PREVIEW, use WITH_ABI_VERSION_2 instead diff --git a/api/include/opentelemetry/std/span.h b/api/include/opentelemetry/std/span.h index 2a3dc12a84..1160d54fbe 100644 --- a/api/include/opentelemetry/std/span.h +++ b/api/include/opentelemetry/std/span.h @@ -60,7 +60,7 @@ OPENTELEMETRY_END_NAMESPACE OPENTELEMETRY_BEGIN_NAMESPACE namespace nostd { -constexpr std::size_t dynamic_extent = (std::numeric_limits::max()); +constexpr std::size_t dynamic_extent = (std::numeric_limits::max)(); template using span = std::span; From 51c2ee567924add9dc66b0e119e2757bdfca688f Mon Sep 17 00:00:00 2001 From: Marc Alff Date: Thu, 14 Dec 2023 00:37:31 +0100 Subject: [PATCH 2/4] [REMOVAL] Remove option WITH_OTLP_HTTP_SSL_PREVIEW (#2435) --- CHANGELOG.md | 12 +++++ CMakeLists.txt | 14 ----- api/CMakeLists.txt | 15 ------ ci/do_ci.sh | 8 --- .../exporters/otlp/otlp_environment.h | 2 - .../exporters/otlp/otlp_http_client.h | 16 +----- .../otlp/otlp_http_exporter_options.h | 4 -- .../otlp_http_log_record_exporter_options.h | 4 -- .../otlp/otlp_http_metric_exporter_options.h | 4 -- exporters/otlp/src/otlp_environment.cc | 4 -- exporters/otlp/src/otlp_http_client.cc | 2 - exporters/otlp/src/otlp_http_exporter.cc | 4 -- .../otlp/src/otlp_http_exporter_options.cc | 4 -- .../otlp/src/otlp_http_log_record_exporter.cc | 4 -- .../otlp_http_log_record_exporter_options.cc | 4 -- .../otlp/src/otlp_http_metric_exporter.cc | 4 -- .../src/otlp_http_metric_exporter_options.cc | 4 -- .../otlp/test/otlp_http_exporter_test.cc | 15 ++---- .../otlp_http_log_record_exporter_test.cc | 15 ++---- .../test/otlp_http_metric_exporter_test.cc | 15 ++---- exporters/zipkin/test/zipkin_exporter_test.cc | 24 --------- .../ext/http/client/curl/http_client_curl.h | 20 +------ .../http/client/curl/http_operation_curl.h | 4 -- .../ext/http/client/http_client.h | 32 ++--------- ext/src/http/client/curl/http_client_curl.cc | 5 +- .../http/client/curl/http_operation_curl.cc | 54 ++++++++----------- ext/test/http/curl_http_test.cc | 23 +++----- functional/otlp/func_http_main.cc | 16 ------ .../http/client/nosend/http_client_nosend.h | 4 -- 29 files changed, 63 insertions(+), 273 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e305d85948..b55c3fa223 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,9 +15,21 @@ Increment the: ## [Unreleased] +* [REMOVAL] Remove option WITH_OTLP_HTTP_SSL_PREVIEW + [#2435](https://github.com/open-telemetry/opentelemetry-cpp/pull/2435) * [BUILD] Fix removing of NOMINMAX on Windows [#2449](https://github.com/open-telemetry/opentelemetry-cpp/pull/2449) +Important changes: + +Breaking changes: + +* [REMOVAL] Remove option WITH_OTLP_HTTP_SSL_PREVIEW + [#2435](https://github.com/open-telemetry/opentelemetry-cpp/pull/2435) + * CMake options `WITH_OTLP_HTTP_SSL_PREVIEW` + and `WITH_OTLP_HTTP_SSL_TLS_PREVIEW` are removed. + Building opentelemetry-cpp without SSL support is no longer possible. + ## [1.13.0] 2023-12-06 * [BUILD] Remove WITH_REMOVE_METER_PREVIEW, use WITH_ABI_VERSION_2 instead diff --git a/CMakeLists.txt b/CMakeLists.txt index c61925e97b..6fa071f353 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -276,13 +276,6 @@ endif() option(WITH_ASYNC_EXPORT_PREVIEW "Whether to enable async export" OFF) -# STABLE -option(WITH_OTLP_HTTP_SSL_PREVIEW "Whether to enable otlp http ssl export" ON) - -# STABLE -option(WITH_OTLP_HTTP_SSL_TLS_PREVIEW - "Whether to enable otlp http ssl tls min/max/cipher options" ON) - # Exemplar specs status is experimental, so behind feature flag by default option(WITH_METRICS_EXEMPLAR_PREVIEW "Whether to enable exemplar within metrics" OFF) @@ -295,13 +288,6 @@ if(WITH_EXAMPLES_HTTP AND NOT WITH_EXAMPLES) message(FATAL_ERROR "WITH_EXAMPLES_HTTP=ON requires WITH_EXAMPLES=ON") endif() -if(WITH_OTLP_HTTP_SSL_TLS_PREVIEW AND NOT WITH_OTLP_HTTP_SSL_PREVIEW) - message( - FATAL_ERROR - "WITH_OTLP_HTTP_SSL_TLS_PREVIEW=ON requires WITH_OTLP_HTTP_SSL_PREVIEW=ON" - ) -endif() - find_package(Threads) function(install_windows_deps) diff --git a/api/CMakeLists.txt b/api/CMakeLists.txt index fc26d9083f..4bb6b88c89 100644 --- a/api/CMakeLists.txt +++ b/api/CMakeLists.txt @@ -117,21 +117,6 @@ target_compile_definitions( opentelemetry_api INTERFACE OPENTELEMETRY_ABI_VERSION_NO=${OPENTELEMETRY_ABI_VERSION_NO}) -# A better place should be in sdk, not api -if(WITH_OTLP_HTTP_SSL_PREVIEW) - target_compile_definitions(opentelemetry_api - INTERFACE ENABLE_OTLP_HTTP_SSL_PREVIEW) - target_compile_definitions(opentelemetry_api - INTERFACE ENABLE_HTTP_SSL_PREVIEW) - - if(WITH_OTLP_HTTP_SSL_TLS_PREVIEW) - target_compile_definitions(opentelemetry_api - INTERFACE ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW) - target_compile_definitions(opentelemetry_api - INTERFACE ENABLE_HTTP_SSL_TLS_PREVIEW) - endif() -endif() - if(WITH_OTLP_GRPC_SSL_MTLS_PREVIEW) target_compile_definitions(opentelemetry_api INTERFACE ENABLE_OTLP_GRPC_SSL_MTLS_PREVIEW) diff --git a/ci/do_ci.sh b/ci/do_ci.sh index de03a2585e..fa8249563c 100755 --- a/ci/do_ci.sh +++ b/ci/do_ci.sh @@ -110,8 +110,6 @@ elif [[ "$1" == "cmake.maintainer.sync.test" ]]; then rm -rf * cmake ${CMAKE_OPTIONS[@]} \ -DWITH_OTLP_HTTP=ON \ - -DWITH_OTLP_HTTP_SSL_PREVIEW=ON \ - -DWITH_OTLP_HTTP_SSL_TLS_PREVIEW=ON \ -DWITH_PROMETHEUS=ON \ -DWITH_EXAMPLES=ON \ -DWITH_EXAMPLES_HTTP=ON \ @@ -132,8 +130,6 @@ elif [[ "$1" == "cmake.maintainer.async.test" ]]; then rm -rf * cmake ${CMAKE_OPTIONS[@]} \ -DWITH_OTLP_HTTP=ON \ - -DWITH_OTLP_HTTP_SSL_PREVIEW=ON \ - -DWITH_OTLP_HTTP_SSL_TLS_PREVIEW=ON \ -DWITH_PROMETHEUS=ON \ -DWITH_EXAMPLES=ON \ -DWITH_EXAMPLES_HTTP=ON \ @@ -155,8 +151,6 @@ elif [[ "$1" == "cmake.maintainer.cpp11.async.test" ]]; then cmake ${CMAKE_OPTIONS[@]} \ -DCMAKE_CXX_STANDARD=11 \ -DWITH_OTLP_HTTP=ON \ - -DWITH_OTLP_HTTP_SSL_PREVIEW=ON \ - -DWITH_OTLP_HTTP_SSL_TLS_PREVIEW=ON \ -DWITH_PROMETHEUS=ON \ -DWITH_EXAMPLES=ON \ -DWITH_EXAMPLES_HTTP=ON \ @@ -176,8 +170,6 @@ elif [[ "$1" == "cmake.maintainer.abiv2.test" ]]; then rm -rf * cmake ${CMAKE_OPTIONS[@]} \ -DWITH_OTLP_HTTP=ON \ - -DWITH_OTLP_HTTP_SSL_PREVIEW=ON \ - -DWITH_OTLP_HTTP_SSL_TLS_PREVIEW=ON \ -DWITH_PROMETHEUS=ON \ -DWITH_EXAMPLES=ON \ -DWITH_EXAMPLES_HTTP=ON \ diff --git a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_environment.h b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_environment.h index 3be133b4cf..8234dc913e 100644 --- a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_environment.h +++ b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_environment.h @@ -99,7 +99,6 @@ std::string GetOtlpDefaultTracesSslClientCertificateString(); std::string GetOtlpDefaultMetricsSslClientCertificateString(); std::string GetOtlpDefaultLogsSslClientCertificateString(); -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW std::string GetOtlpDefaultTracesSslTlsMinVersion(); std::string GetOtlpDefaultMetricsSslTlsMinVersion(); std::string GetOtlpDefaultLogsSslTlsMinVersion(); @@ -117,7 +116,6 @@ std::string GetOtlpDefaultLogsSslTlsCipher(); std::string GetOtlpDefaultTracesSslTlsCipherSuite(); std::string GetOtlpDefaultMetricsSslTlsCipherSuite(); std::string GetOtlpDefaultLogsSslTlsCipherSuite(); -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ std::chrono::system_clock::duration GetOtlpDefaultTracesTimeout(); std::chrono::system_clock::duration GetOtlpDefaultMetricsTimeout(); diff --git a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_client.h b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_client.h index c41ffb0914..6af73f7e6b 100644 --- a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_client.h +++ b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_client.h @@ -49,10 +49,8 @@ struct OtlpHttpClientOptions { std::string url; -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW /** SSL options. */ ext::http::client::HttpSslOptions ssl_options; -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ // By default, post json data HttpRequestContentType content_type = HttpRequestContentType::kJson; @@ -83,7 +81,6 @@ struct OtlpHttpClientOptions std::string user_agent; inline OtlpHttpClientOptions(nostd::string_view input_url, -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW bool input_ssl_insecure_skip_verify, nostd::string_view input_ssl_ca_cert_path, nostd::string_view input_ssl_ca_cert_string, @@ -91,13 +88,10 @@ struct OtlpHttpClientOptions nostd::string_view input_ssl_client_key_string, nostd::string_view input_ssl_client_cert_path, nostd::string_view input_ssl_client_cert_string, -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW nostd::string_view input_ssl_min_tls, nostd::string_view input_ssl_max_tls, nostd::string_view input_ssl_cipher, nostd::string_view input_ssl_cipher_suite, -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ HttpRequestContentType input_content_type, JsonBytesMappingKind input_json_bytes_mapping, bool input_use_json_name, @@ -108,7 +102,6 @@ struct OtlpHttpClientOptions std::size_t input_max_requests_per_connection = 8, nostd::string_view input_user_agent = GetOtlpDefaultUserAgent()) : url(input_url), -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW ssl_options(input_url, input_ssl_insecure_skip_verify, input_ssl_ca_cert_path, @@ -116,16 +109,11 @@ struct OtlpHttpClientOptions input_ssl_client_key_path, input_ssl_client_key_string, input_ssl_client_cert_path, - input_ssl_client_cert_string -# ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW - , + input_ssl_client_cert_string, input_ssl_min_tls, input_ssl_max_tls, input_ssl_cipher, - input_ssl_cipher_suite -# endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ - ), -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ + input_ssl_cipher_suite), content_type(input_content_type), json_bytes_mapping(input_json_bytes_mapping), use_json_name(input_use_json_name), diff --git a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_exporter_options.h b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_exporter_options.h index 9200a506b8..f7ed0eb3b9 100644 --- a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_exporter_options.h +++ b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_exporter_options.h @@ -68,7 +68,6 @@ struct OPENTELEMETRY_EXPORT OtlpHttpExporterOptions std::size_t max_requests_per_connection; #endif -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW /** True do disable SSL. */ bool ssl_insecure_skip_verify; @@ -89,9 +88,7 @@ struct OPENTELEMETRY_EXPORT OtlpHttpExporterOptions /** CLIENT CERT, as a string. */ std::string ssl_client_cert_string; -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW /** Minimum TLS version. */ std::string ssl_min_tls; @@ -103,7 +100,6 @@ struct OPENTELEMETRY_EXPORT OtlpHttpExporterOptions /** TLS cipher suite. */ std::string ssl_cipher_suite; -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ }; } // namespace otlp diff --git a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_log_record_exporter_options.h b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_log_record_exporter_options.h index e2a6264675..1c34327a3c 100644 --- a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_log_record_exporter_options.h +++ b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_log_record_exporter_options.h @@ -68,7 +68,6 @@ struct OPENTELEMETRY_EXPORT OtlpHttpLogRecordExporterOptions std::size_t max_requests_per_connection; #endif -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW /** True do disable SSL. */ bool ssl_insecure_skip_verify; @@ -89,9 +88,7 @@ struct OPENTELEMETRY_EXPORT OtlpHttpLogRecordExporterOptions /** CLIENT CERT, as a string. */ std::string ssl_client_cert_string; -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW /** Minimum TLS version. */ std::string ssl_min_tls; @@ -103,7 +100,6 @@ struct OPENTELEMETRY_EXPORT OtlpHttpLogRecordExporterOptions /** TLS cipher suite. */ std::string ssl_cipher_suite; -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ }; } // namespace otlp diff --git a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_metric_exporter_options.h b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_metric_exporter_options.h index 38446be73b..4f30451387 100644 --- a/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_metric_exporter_options.h +++ b/exporters/otlp/include/opentelemetry/exporters/otlp/otlp_http_metric_exporter_options.h @@ -71,7 +71,6 @@ struct OPENTELEMETRY_EXPORT OtlpHttpMetricExporterOptions std::size_t max_requests_per_connection; #endif -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW /** True do disable SSL. */ bool ssl_insecure_skip_verify; @@ -92,9 +91,7 @@ struct OPENTELEMETRY_EXPORT OtlpHttpMetricExporterOptions /** CLIENT CERT, as a string. */ std::string ssl_client_cert_string; -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW /** Minimum TLS version. */ std::string ssl_min_tls; @@ -106,7 +103,6 @@ struct OPENTELEMETRY_EXPORT OtlpHttpMetricExporterOptions /** TLS cipher suite. */ std::string ssl_cipher_suite; -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ }; } // namespace otlp diff --git a/exporters/otlp/src/otlp_environment.cc b/exporters/otlp/src/otlp_environment.cc index 5324b40213..a355b13162 100644 --- a/exporters/otlp/src/otlp_environment.cc +++ b/exporters/otlp/src/otlp_environment.cc @@ -660,8 +660,6 @@ std::string GetOtlpDefaultLogsSslClientCertificateString() return std::string{}; } -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW - /* EXPERIMENTAL: Environment variable names do not exist in the spec, @@ -872,8 +870,6 @@ std::string GetOtlpDefaultLogsSslTlsCipherSuite() return std::string{}; } -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ - std::chrono::system_clock::duration GetOtlpDefaultTracesTimeout() { constexpr char kSignalEnv[] = "OTEL_EXPORTER_OTLP_TRACES_TIMEOUT"; diff --git a/exporters/otlp/src/otlp_http_client.cc b/exporters/otlp/src/otlp_http_client.cc index c6bc1e1122..9c57a9bd83 100644 --- a/exporters/otlp/src/otlp_http_client.cc +++ b/exporters/otlp/src/otlp_http_client.cc @@ -951,9 +951,7 @@ OtlpHttpClient::createSession( request->AddHeader(header.first, header.second); } request->SetUri(http_uri_); -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW request->SetSslOptions(options_.ssl_options); -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ request->SetTimeoutMs(std::chrono::duration_cast(options_.timeout)); request->SetMethod(http_client::Method::Post); request->SetBody(body_vec); diff --git a/exporters/otlp/src/otlp_http_exporter.cc b/exporters/otlp/src/otlp_http_exporter.cc index 6732e31431..6059db36a4 100644 --- a/exporters/otlp/src/otlp_http_exporter.cc +++ b/exporters/otlp/src/otlp_http_exporter.cc @@ -26,7 +26,6 @@ OtlpHttpExporter::OtlpHttpExporter() : OtlpHttpExporter(OtlpHttpExporterOptions( OtlpHttpExporter::OtlpHttpExporter(const OtlpHttpExporterOptions &options) : options_(options), http_client_(new OtlpHttpClient(OtlpHttpClientOptions(options.url, -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW options.ssl_insecure_skip_verify, options.ssl_ca_cert_path, options.ssl_ca_cert_string, @@ -34,13 +33,10 @@ OtlpHttpExporter::OtlpHttpExporter(const OtlpHttpExporterOptions &options) options.ssl_client_key_string, options.ssl_client_cert_path, options.ssl_client_cert_string, -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW options.ssl_min_tls, options.ssl_max_tls, options.ssl_cipher, options.ssl_cipher_suite, -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ options.content_type, options.json_bytes_mapping, options.use_json_name, diff --git a/exporters/otlp/src/otlp_http_exporter_options.cc b/exporters/otlp/src/otlp_http_exporter_options.cc index 91121e0c35..3b8c6ad5b8 100644 --- a/exporters/otlp/src/otlp_http_exporter_options.cc +++ b/exporters/otlp/src/otlp_http_exporter_options.cc @@ -29,7 +29,6 @@ OtlpHttpExporterOptions::OtlpHttpExporterOptions() max_requests_per_connection = 8; #endif /* ENABLE_ASYNC_EXPORT */ -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW ssl_insecure_skip_verify = false; ssl_ca_cert_path = GetOtlpDefaultTracesSslCertificatePath(); ssl_ca_cert_string = GetOtlpDefaultTracesSslCertificateString(); @@ -37,14 +36,11 @@ OtlpHttpExporterOptions::OtlpHttpExporterOptions() ssl_client_key_string = GetOtlpDefaultTracesSslClientKeyString(); ssl_client_cert_path = GetOtlpDefaultTracesSslClientCertificatePath(); ssl_client_cert_string = GetOtlpDefaultTracesSslClientCertificateString(); -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW ssl_min_tls = GetOtlpDefaultTracesSslTlsMinVersion(); ssl_max_tls = GetOtlpDefaultTracesSslTlsMaxVersion(); ssl_cipher = GetOtlpDefaultTracesSslTlsCipher(); ssl_cipher_suite = GetOtlpDefaultTracesSslTlsCipherSuite(); -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ } OtlpHttpExporterOptions::~OtlpHttpExporterOptions() {} diff --git a/exporters/otlp/src/otlp_http_log_record_exporter.cc b/exporters/otlp/src/otlp_http_log_record_exporter.cc index 9414e2fd76..e16c5d0008 100644 --- a/exporters/otlp/src/otlp_http_log_record_exporter.cc +++ b/exporters/otlp/src/otlp_http_log_record_exporter.cc @@ -29,7 +29,6 @@ OtlpHttpLogRecordExporter::OtlpHttpLogRecordExporter( const OtlpHttpLogRecordExporterOptions &options) : options_(options), http_client_(new OtlpHttpClient(OtlpHttpClientOptions(options.url, -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW options.ssl_insecure_skip_verify, options.ssl_ca_cert_path, options.ssl_ca_cert_string, @@ -37,13 +36,10 @@ OtlpHttpLogRecordExporter::OtlpHttpLogRecordExporter( options.ssl_client_key_string, options.ssl_client_cert_path, options.ssl_client_cert_string, -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW options.ssl_min_tls, options.ssl_max_tls, options.ssl_cipher, options.ssl_cipher_suite, -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ options.content_type, options.json_bytes_mapping, options.use_json_name, diff --git a/exporters/otlp/src/otlp_http_log_record_exporter_options.cc b/exporters/otlp/src/otlp_http_log_record_exporter_options.cc index bda37b9730..2f58bce768 100644 --- a/exporters/otlp/src/otlp_http_log_record_exporter_options.cc +++ b/exporters/otlp/src/otlp_http_log_record_exporter_options.cc @@ -29,7 +29,6 @@ OtlpHttpLogRecordExporterOptions::OtlpHttpLogRecordExporterOptions() max_requests_per_connection = 8; #endif -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW ssl_insecure_skip_verify = false; ssl_ca_cert_path = GetOtlpDefaultLogsSslCertificatePath(); ssl_ca_cert_string = GetOtlpDefaultLogsSslCertificateString(); @@ -37,14 +36,11 @@ OtlpHttpLogRecordExporterOptions::OtlpHttpLogRecordExporterOptions() ssl_client_key_string = GetOtlpDefaultLogsSslClientKeyString(); ssl_client_cert_path = GetOtlpDefaultLogsSslClientCertificatePath(); ssl_client_cert_string = GetOtlpDefaultLogsSslClientCertificateString(); -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW ssl_min_tls = GetOtlpDefaultLogsSslTlsMinVersion(); ssl_max_tls = GetOtlpDefaultLogsSslTlsMaxVersion(); ssl_cipher = GetOtlpDefaultLogsSslTlsCipher(); ssl_cipher_suite = GetOtlpDefaultLogsSslTlsCipherSuite(); -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ } OtlpHttpLogRecordExporterOptions::~OtlpHttpLogRecordExporterOptions() {} diff --git a/exporters/otlp/src/otlp_http_metric_exporter.cc b/exporters/otlp/src/otlp_http_metric_exporter.cc index e4f667eb3e..816f4eee44 100644 --- a/exporters/otlp/src/otlp_http_metric_exporter.cc +++ b/exporters/otlp/src/otlp_http_metric_exporter.cc @@ -29,7 +29,6 @@ OtlpHttpMetricExporter::OtlpHttpMetricExporter(const OtlpHttpMetricExporterOptio aggregation_temporality_selector_{ OtlpMetricUtils::ChooseTemporalitySelector(options_.aggregation_temporality)}, http_client_(new OtlpHttpClient(OtlpHttpClientOptions(options.url, -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW options.ssl_insecure_skip_verify, options.ssl_ca_cert_path, options.ssl_ca_cert_string, @@ -37,13 +36,10 @@ OtlpHttpMetricExporter::OtlpHttpMetricExporter(const OtlpHttpMetricExporterOptio options.ssl_client_key_string, options.ssl_client_cert_path, options.ssl_client_cert_string, -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW options.ssl_min_tls, options.ssl_max_tls, options.ssl_cipher, options.ssl_cipher_suite, -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ options.content_type, options.json_bytes_mapping, options.use_json_name, diff --git a/exporters/otlp/src/otlp_http_metric_exporter_options.cc b/exporters/otlp/src/otlp_http_metric_exporter_options.cc index 4dc0f40631..ffcd502bd4 100644 --- a/exporters/otlp/src/otlp_http_metric_exporter_options.cc +++ b/exporters/otlp/src/otlp_http_metric_exporter_options.cc @@ -30,7 +30,6 @@ OtlpHttpMetricExporterOptions::OtlpHttpMetricExporterOptions() max_requests_per_connection = 8; #endif -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW ssl_insecure_skip_verify = false; ssl_ca_cert_path = GetOtlpDefaultMetricsSslCertificatePath(); ssl_ca_cert_string = GetOtlpDefaultMetricsSslCertificateString(); @@ -38,14 +37,11 @@ OtlpHttpMetricExporterOptions::OtlpHttpMetricExporterOptions() ssl_client_key_string = GetOtlpDefaultMetricsSslClientKeyString(); ssl_client_cert_path = GetOtlpDefaultMetricsSslClientCertificatePath(); ssl_client_cert_string = GetOtlpDefaultMetricsSslClientCertificateString(); -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW ssl_min_tls = GetOtlpDefaultMetricsSslTlsMinVersion(); ssl_max_tls = GetOtlpDefaultMetricsSslTlsMaxVersion(); ssl_cipher = GetOtlpDefaultMetricsSslTlsCipher(); ssl_cipher_suite = GetOtlpDefaultMetricsSslTlsCipherSuite(); -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ } OtlpHttpMetricExporterOptions::~OtlpHttpMetricExporterOptions() {} diff --git a/exporters/otlp/test/otlp_http_exporter_test.cc b/exporters/otlp/test/otlp_http_exporter_test.cc index 1c76ad0d02..63f919c6cc 100644 --- a/exporters/otlp/test/otlp_http_exporter_test.cc +++ b/exporters/otlp/test/otlp_http_exporter_test.cc @@ -61,20 +61,15 @@ OtlpHttpClientOptions MakeOtlpHttpClientOptions(HttpRequestContentType content_t options.http_headers.insert( std::make_pair("Custom-Header-Key", "Custom-Header-Value")); OtlpHttpClientOptions otlp_http_client_options( - options.url, -# ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW - false, /* ssl_insecure_skip_verify */ + options.url, false, /* ssl_insecure_skip_verify */ "", /* ssl_ca_cert_path */ "", /* ssl_ca_cert_string */ "", /* ssl_client_key_path */ "", /* ssl_client_key_string */ "", /* ssl_client_cert_path */ "", /* ssl_client_cert_string */ -# endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -# ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW - "", /* ssl_min_tls */ - "", /* ssl_max_tls */ - "", /* ssl_cipher */ - "", /* ssl_cipher_suite */ -# endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ + "", /* ssl_min_tls */ + "", /* ssl_max_tls */ + "", /* ssl_cipher */ + "", /* ssl_cipher_suite */ options.content_type, options.json_bytes_mapping, options.use_json_name, options.console_debug, options.timeout, options.http_headers); if (!async_mode) diff --git a/exporters/otlp/test/otlp_http_log_record_exporter_test.cc b/exporters/otlp/test/otlp_http_log_record_exporter_test.cc index 44fa812a35..611bebb541 100644 --- a/exporters/otlp/test/otlp_http_log_record_exporter_test.cc +++ b/exporters/otlp/test/otlp_http_log_record_exporter_test.cc @@ -60,20 +60,15 @@ OtlpHttpClientOptions MakeOtlpHttpClientOptions(HttpRequestContentType content_t options.http_headers.insert( std::make_pair("Custom-Header-Key", "Custom-Header-Value")); OtlpHttpClientOptions otlp_http_client_options( - options.url, -# ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW - false, /* ssl_insecure_skip_verify */ + options.url, false, /* ssl_insecure_skip_verify */ "", /* ssl_ca_cert_path */ "", /* ssl_ca_cert_string */ "", /* ssl_client_key_path */ "", /* ssl_client_key_string */ "", /* ssl_client_cert_path */ "", /* ssl_client_cert_string */ -# endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -# ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW - "", /* ssl_min_tls */ - "", /* ssl_max_tls */ - "", /* ssl_cipher */ - "", /* ssl_cipher_suite */ -# endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ + "", /* ssl_min_tls */ + "", /* ssl_max_tls */ + "", /* ssl_cipher */ + "", /* ssl_cipher_suite */ options.content_type, options.json_bytes_mapping, options.use_json_name, options.console_debug, options.timeout, options.http_headers); if (!async_mode) diff --git a/exporters/otlp/test/otlp_http_metric_exporter_test.cc b/exporters/otlp/test/otlp_http_metric_exporter_test.cc index 8b7688adc0..def56682d3 100644 --- a/exporters/otlp/test/otlp_http_metric_exporter_test.cc +++ b/exporters/otlp/test/otlp_http_metric_exporter_test.cc @@ -67,20 +67,15 @@ OtlpHttpClientOptions MakeOtlpHttpClientOptions(HttpRequestContentType content_t options.http_headers.insert( std::make_pair("Custom-Header-Key", "Custom-Header-Value")); OtlpHttpClientOptions otlp_http_client_options( - options.url, -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW - false, /* ssl_insecure_skip_verify */ + options.url, false, /* ssl_insecure_skip_verify */ "", /* ssl_ca_cert_path */ "", /* ssl_ca_cert_string */ "", /* ssl_client_key_path */ "", /* ssl_client_key_string */ "", /* ssl_client_cert_path */ "", /* ssl_client_cert_string */ -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW - "", /* ssl_min_tls */ - "", /* ssl_max_tls */ - "", /* ssl_cipher */ - "", /* ssl_cipher_suite */ -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ + "", /* ssl_min_tls */ + "", /* ssl_max_tls */ + "", /* ssl_cipher */ + "", /* ssl_cipher_suite */ options.content_type, options.json_bytes_mapping, options.use_json_name, options.console_debug, options.timeout, options.http_headers); if (!async_mode) diff --git a/exporters/zipkin/test/zipkin_exporter_test.cc b/exporters/zipkin/test/zipkin_exporter_test.cc index 870ff427e9..adc81c661b 100644 --- a/exporters/zipkin/test/zipkin_exporter_test.cc +++ b/exporters/zipkin/test/zipkin_exporter_test.cc @@ -60,7 +60,6 @@ class ZipkinExporterTestPeer : public ::testing::Test class MockHttpClient : public opentelemetry::ext::http::client::HttpClientSync { public: -# ifdef ENABLE_HTTP_SSL_PREVIEW MOCK_METHOD(ext::http::client::Result, Post, (const nostd::string_view &, @@ -68,28 +67,13 @@ class MockHttpClient : public opentelemetry::ext::http::client::HttpClientSync const ext::http::client::Body &, const ext::http::client::Headers &), (noexcept, override)); -# else - MOCK_METHOD(ext::http::client::Result, - Post, - (const nostd::string_view &, - const ext::http::client::Body &, - const ext::http::client::Headers &), - (noexcept, override)); -# endif /* ENABLE_HTTP_SSL_PREVIEW */ -# ifdef ENABLE_HTTP_SSL_PREVIEW MOCK_METHOD(ext::http::client::Result, Get, (const nostd::string_view &, const ext::http::client::HttpSslOptions &, const ext::http::client::Headers &), (noexcept, override)); -# else - MOCK_METHOD(ext::http::client::Result, - Get, - (const nostd::string_view &, const ext::http::client::Headers &), - (noexcept, override)); -# endif /* ENABLE_HTTP_SSL_PREVIEW */ }; class IsValidMessageMatcher @@ -169,11 +153,7 @@ TEST_F(ZipkinExporterTestPeer, ExportJsonIntegrationTest) auto expected_url = nostd::string_view{"http://localhost:9411/api/v2/spans"}; -# ifdef ENABLE_HTTP_SSL_PREVIEW EXPECT_CALL(*mock_http_client, Post(expected_url, _, IsValidMessage(report_trace_id), _)) -# else - EXPECT_CALL(*mock_http_client, Post(expected_url, IsValidMessage(report_trace_id), _)) -# endif /* ENABLE_HTTP_SSL_PREVIEW */ .Times(Exactly(1)) .WillOnce(Return(ByMove(ext::http::client::Result{ @@ -199,11 +179,7 @@ TEST_F(ZipkinExporterTestPeer, ShutdownTest) // exporter should not be shutdown by default nostd::span> batch_1(&recordable_1, 1); -# ifdef ENABLE_HTTP_SSL_PREVIEW EXPECT_CALL(*mock_http_client, Post(_, _, _, _)) -# else - EXPECT_CALL(*mock_http_client, Post(_, _, _)) -# endif /* ENABLE_HTTP_SSL_PREVIEW */ .Times(Exactly(1)) .WillOnce(Return(ByMove(ext::http::client::Result{ diff --git a/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h b/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h index 45ee13d55c..93d407f24a 100644 --- a/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h +++ b/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h @@ -58,12 +58,10 @@ class Request : public opentelemetry::ext::http::client::Request method_ = method; } -#ifdef ENABLE_HTTP_SSL_PREVIEW void SetSslOptions(const HttpSslOptions &ssl_options) noexcept override { ssl_options_ = ssl_options; } -#endif /* ENABLE_HTTP_SSL_PREVIEW */ void SetBody(opentelemetry::ext::http::client::Body &body) noexcept override { @@ -93,11 +91,7 @@ class Request : public opentelemetry::ext::http::client::Request public: opentelemetry::ext::http::client::Method method_; - -#ifdef ENABLE_HTTP_SSL_PREVIEW opentelemetry::ext::http::client::HttpSslOptions ssl_options_; -#endif /* ENABLE_HTTP_SSL_PREVIEW */ - opentelemetry::ext::http::client::Body body_; opentelemetry::ext::http::client::Headers headers_; std::string uri_; @@ -225,18 +219,13 @@ class HttpClientSync : public opentelemetry::ext::http::client::HttpClientSync opentelemetry::ext::http::client::Result Get( const nostd::string_view &url, -#ifdef ENABLE_HTTP_SSL_PREVIEW const opentelemetry::ext::http::client::HttpSslOptions &ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ const opentelemetry::ext::http::client::Headers &headers) noexcept override { opentelemetry::ext::http::client::Body body; HttpOperation curl_operation(opentelemetry::ext::http::client::Method::Get, url.data(), -#ifdef ENABLE_HTTP_SSL_PREVIEW - ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ - nullptr, headers, body); + ssl_options, nullptr, headers, body); curl_operation.SendSync(); auto session_state = curl_operation.GetSessionState(); @@ -258,17 +247,12 @@ class HttpClientSync : public opentelemetry::ext::http::client::HttpClientSync opentelemetry::ext::http::client::Result Post( const nostd::string_view &url, -#ifdef ENABLE_HTTP_SSL_PREVIEW const opentelemetry::ext::http::client::HttpSslOptions &ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ const Body &body, const opentelemetry::ext::http::client::Headers &headers) noexcept override { HttpOperation curl_operation(opentelemetry::ext::http::client::Method::Post, url.data(), -#ifdef ENABLE_HTTP_SSL_PREVIEW - ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ - nullptr, headers, body); + ssl_options, nullptr, headers, body); curl_operation.SendSync(); auto session_state = curl_operation.GetSessionState(); if (curl_operation.WasAborted()) diff --git a/ext/include/opentelemetry/ext/http/client/curl/http_operation_curl.h b/ext/include/opentelemetry/ext/http/client/curl/http_operation_curl.h index 48ce11123c..587e74a238 100644 --- a/ext/include/opentelemetry/ext/http/client/curl/http_operation_curl.h +++ b/ext/include/opentelemetry/ext/http/client/curl/http_operation_curl.h @@ -139,9 +139,7 @@ class HttpOperation */ HttpOperation(opentelemetry::ext::http::client::Method method, std::string url, -#ifdef ENABLE_HTTP_SSL_PREVIEW const opentelemetry::ext::http::client::HttpSslOptions &ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ opentelemetry::ext::http::client::EventHandler *event_handle, // Default empty headers and empty request body const opentelemetry::ext::http::client::Headers &request_headers = @@ -290,9 +288,7 @@ class HttpOperation opentelemetry::ext::http::client::Method method_; std::string url_; -#ifdef ENABLE_HTTP_SSL_PREVIEW const opentelemetry::ext::http::client::HttpSslOptions &ssl_options_; -#endif /* ENABLE_HTTP_SSL_PREVIEW */ const Headers &request_headers_; const opentelemetry::ext::http::client::Body &request_body_; diff --git a/ext/include/opentelemetry/ext/http/client/http_client.h b/ext/include/opentelemetry/ext/http/client/http_client.h index c3559cb0eb..7fee1beb35 100644 --- a/ext/include/opentelemetry/ext/http/client/http_client.h +++ b/ext/include/opentelemetry/ext/http/client/http_client.h @@ -110,7 +110,6 @@ struct cmp_ic }; using Headers = std::multimap; -#ifdef ENABLE_HTTP_SSL_PREVIEW struct HttpSslOptions { HttpSslOptions() {} @@ -122,15 +121,11 @@ struct HttpSslOptions nostd::string_view input_ssl_client_key_path, nostd::string_view input_ssl_client_key_string, nostd::string_view input_ssl_client_cert_path, - nostd::string_view input_ssl_client_cert_string -# ifdef ENABLE_HTTP_SSL_TLS_PREVIEW - , + nostd::string_view input_ssl_client_cert_string, nostd::string_view input_ssl_min_tls, nostd::string_view input_ssl_max_tls, nostd::string_view input_ssl_cipher, - nostd::string_view input_ssl_cipher_suite -# endif /* ENABLE_HTTP_SSL_TLS_PREVIEW */ - ) + nostd::string_view input_ssl_cipher_suite) : use_ssl(false), ssl_insecure_skip_verify(input_ssl_insecure_skip_verify), ssl_ca_cert_path(input_ssl_ca_cert_path), @@ -138,15 +133,11 @@ struct HttpSslOptions ssl_client_key_path(input_ssl_client_key_path), ssl_client_key_string(input_ssl_client_key_string), ssl_client_cert_path(input_ssl_client_cert_path), - ssl_client_cert_string(input_ssl_client_cert_string) - -# ifdef ENABLE_HTTP_SSL_TLS_PREVIEW - , + ssl_client_cert_string(input_ssl_client_cert_string), ssl_min_tls(input_ssl_min_tls), ssl_max_tls(input_ssl_max_tls), ssl_cipher(input_ssl_cipher), ssl_cipher_suite(input_ssl_cipher_suite) -# endif /* ENABLE_HTTP_SSL_TLS_PREVIEW */ { /* Use SSL if url starts with "https:" */ if (strncmp(url.data(), "https:", 6) == 0) @@ -192,7 +183,6 @@ struct HttpSslOptions */ std::string ssl_client_cert_string{}; -# ifdef ENABLE_HTTP_SSL_TLS_PREVIEW /** Minimum SSL version to use. Valid values are: @@ -230,9 +220,7 @@ struct HttpSslOptions Cipher names depends on the underlying CURL implementation. */ std::string ssl_cipher_suite{}; -# endif /* ENABLE_HTTP_SSL_TLS_PREVIEW */ }; -#endif /* ENABLE_HTTP_SSL_PREVIEW */ class Request { @@ -241,9 +229,7 @@ class Request virtual void SetUri(nostd::string_view uri) noexcept = 0; -#ifdef ENABLE_HTTP_SSL_PREVIEW virtual void SetSslOptions(const HttpSslOptions &options) noexcept = 0; -#endif /* ENABLE_HTTP_SSL_PREVIEW */ virtual void SetBody(Body &body) noexcept = 0; @@ -368,36 +354,24 @@ class HttpClientSync public: Result GetNoSsl(const nostd::string_view &url, const Headers &headers = {{}}) noexcept { -#ifdef ENABLE_HTTP_SSL_PREVIEW static const HttpSslOptions no_ssl; return Get(url, no_ssl, headers); -#else - return Get(url, headers); -#endif /* ENABLE_HTTP_SSL_PREVIEW */ } virtual Result PostNoSsl(const nostd::string_view &url, const Body &body, const Headers &headers = {{"content-type", "application/json"}}) noexcept { -#ifdef ENABLE_HTTP_SSL_PREVIEW static const HttpSslOptions no_ssl; return Post(url, no_ssl, body, headers); -#else - return Post(url, body, headers); -#endif /* ENABLE_HTTP_SSL_PREVIEW */ } virtual Result Get(const nostd::string_view &url, -#ifdef ENABLE_HTTP_SSL_PREVIEW const HttpSslOptions &ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ const Headers & = {{}}) noexcept = 0; virtual Result Post(const nostd::string_view &url, -#ifdef ENABLE_HTTP_SSL_PREVIEW const HttpSslOptions &ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ const Body &body, const Headers & = {{"content-type", "application/json"}}) noexcept = 0; diff --git a/ext/src/http/client/curl/http_client_curl.cc b/ext/src/http/client/curl/http_client_curl.cc index 287059a1c6..872519fb11 100644 --- a/ext/src/http/client/curl/http_client_curl.cc +++ b/ext/src/http/client/curl/http_client_curl.cc @@ -48,10 +48,7 @@ void Session::SendRequest( reuse_connection = session_id_ % http_client_.GetMaxSessionsPerConnection() != 0; } - curl_operation_.reset(new HttpOperation(http_request_->method_, url, -#ifdef ENABLE_HTTP_SSL_PREVIEW - http_request_->ssl_options_, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ + curl_operation_.reset(new HttpOperation(http_request_->method_, url, http_request_->ssl_options_, callback_ptr, http_request_->headers_, http_request_->body_, false, http_request_->timeout_ms_, reuse_connection)); diff --git a/ext/src/http/client/curl/http_operation_curl.cc b/ext/src/http/client/curl/http_operation_curl.cc index 22b2565e6f..f24d3fa53b 100644 --- a/ext/src/http/client/curl/http_operation_curl.cc +++ b/ext/src/http/client/curl/http_operation_curl.cc @@ -235,9 +235,7 @@ void HttpOperation::DispatchEvent(opentelemetry::ext::http::client::SessionState HttpOperation::HttpOperation(opentelemetry::ext::http::client::Method method, std::string url, -#ifdef ENABLE_HTTP_SSL_PREVIEW const HttpSslOptions &ssl_options, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ opentelemetry::ext::http::client::EventHandler *event_handle, // Default empty headers and empty request body const opentelemetry::ext::http::client::Headers &request_headers, @@ -258,9 +256,7 @@ HttpOperation::HttpOperation(opentelemetry::ext::http::client::Method method, event_handle_(event_handle), method_(method), url_(url), -#ifdef ENABLE_HTTP_SSL_PREVIEW ssl_options_(ssl_options), -#endif /* ENABLE_HTTP_SSL_PREVIEW */ // Local vars request_headers_(request_headers), request_body_(request_body), @@ -438,10 +434,9 @@ void HttpOperation::Cleanup() # define HAVE_TLS_VERSION #endif -#ifdef ENABLE_HTTP_SSL_TLS_PREVIEW static long parse_min_ssl_version(std::string version) { -# ifdef HAVE_TLS_VERSION +#ifdef HAVE_TLS_VERSION if (version == "1.0") { return CURL_SSLVERSION_TLSv1_0; @@ -461,14 +456,14 @@ static long parse_min_ssl_version(std::string version) { return CURL_SSLVERSION_TLSv1_3; } -# endif +#endif return 0; } static long parse_max_ssl_version(std::string version) { -# ifdef HAVE_TLS_VERSION +#ifdef HAVE_TLS_VERSION if (version == "1.0") { return CURL_SSLVERSION_MAX_TLSv1_0; @@ -488,11 +483,10 @@ static long parse_max_ssl_version(std::string version) { return CURL_SSLVERSION_MAX_TLSv1_3; } -# endif +#endif return 0; } -#endif /* ENABLE_HTTP_SSL_TLS_PREVIEW */ const char *HttpOperation::GetCurlErrorMessage(CURLcode code) { @@ -601,7 +595,6 @@ CURLcode HttpOperation::Setup() return rc; } -#ifdef ENABLE_HTTP_SSL_PREVIEW if (ssl_options_.use_ssl) { /* 1 - CA CERT */ @@ -618,7 +611,7 @@ CURLcode HttpOperation::Setup() } else if (!ssl_options_.ssl_ca_cert_string.empty()) { -# if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 77, 0) +#if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 77, 0) const char *data = ssl_options_.ssl_ca_cert_string.c_str(); size_t data_len = ssl_options_.ssl_ca_cert_string.length(); @@ -632,11 +625,11 @@ CURLcode HttpOperation::Setup() { return rc; } -# else +#else // CURL 7.77.0 required for CURLOPT_CAINFO_BLOB. OTEL_INTERNAL_LOG_ERROR("CURL 7.77.0 required for CA CERT STRING"); return CURLE_UNKNOWN_OPTION; -# endif +#endif } /* 2 - CLIENT KEY */ @@ -659,7 +652,7 @@ CURLcode HttpOperation::Setup() } else if (!ssl_options_.ssl_client_key_string.empty()) { -# if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 71, 0) +#if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 71, 0) const char *data = ssl_options_.ssl_client_key_string.c_str(); size_t data_len = ssl_options_.ssl_client_key_string.length(); @@ -679,11 +672,11 @@ CURLcode HttpOperation::Setup() { return rc; } -# else +#else // CURL 7.71.0 required for CURLOPT_SSLKEY_BLOB. OTEL_INTERNAL_LOG_ERROR("CURL 7.71.0 required for CLIENT KEY STRING"); return CURLE_UNKNOWN_OPTION; -# endif +#endif } /* 3 - CLIENT CERT */ @@ -706,7 +699,7 @@ CURLcode HttpOperation::Setup() } else if (!ssl_options_.ssl_client_cert_string.empty()) { -# if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 71, 0) +#if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 71, 0) const char *data = ssl_options_.ssl_client_cert_string.c_str(); size_t data_len = ssl_options_.ssl_client_cert_string.length(); @@ -726,21 +719,20 @@ CURLcode HttpOperation::Setup() { return rc; } -# else +#else // CURL 7.71.0 required for CURLOPT_SSLCERT_BLOB. OTEL_INTERNAL_LOG_ERROR("CURL 7.71.0 required for CLIENT CERT STRING"); return CURLE_UNKNOWN_OPTION; -# endif +#endif } -# ifdef ENABLE_HTTP_SSL_TLS_PREVIEW /* 4 - TLS */ long min_ssl_version = 0; if (!ssl_options_.ssl_min_tls.empty()) { -# ifdef HAVE_TLS_VERSION +#ifdef HAVE_TLS_VERSION min_ssl_version = parse_min_ssl_version(ssl_options_.ssl_min_tls); if (min_ssl_version == 0) @@ -748,17 +740,17 @@ CURLcode HttpOperation::Setup() OTEL_INTERNAL_LOG_ERROR("Unknown min TLS version <" << ssl_options_.ssl_min_tls << ">"); return CURLE_UNKNOWN_OPTION; } -# else +#else OTEL_INTERNAL_LOG_ERROR("CURL 7.54.0 required for MIN TLS"); return CURLE_UNKNOWN_OPTION; -# endif +#endif } long max_ssl_version = 0; if (!ssl_options_.ssl_max_tls.empty()) { -# ifdef HAVE_TLS_VERSION +#ifdef HAVE_TLS_VERSION max_ssl_version = parse_max_ssl_version(ssl_options_.ssl_max_tls); if (max_ssl_version == 0) @@ -766,10 +758,10 @@ CURLcode HttpOperation::Setup() OTEL_INTERNAL_LOG_ERROR("Unknown max TLS version <" << ssl_options_.ssl_max_tls << ">"); return CURLE_UNKNOWN_OPTION; } -# else +#else OTEL_INTERNAL_LOG_ERROR("CURL 7.54.0 required for MAX TLS"); return CURLE_UNKNOWN_OPTION; -# endif +#endif } long version_range = min_ssl_version | max_ssl_version; @@ -798,23 +790,22 @@ CURLcode HttpOperation::Setup() if (!ssl_options_.ssl_cipher_suite.empty()) { -# if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 61, 0) +#if LIBCURL_VERSION_NUM >= CURL_VERSION_BITS(7, 61, 0) /* TLS 1.3 */ const char *cipher_list = ssl_options_.ssl_cipher_suite.c_str(); rc = SetCurlStrOption(CURLOPT_TLS13_CIPHERS, cipher_list); -# else +#else // CURL 7.61.0 required for CURLOPT_TLS13_CIPHERS. OTEL_INTERNAL_LOG_ERROR("CURL 7.61.0 required for CIPHER SUITE"); return CURLE_UNKNOWN_OPTION; -# endif +#endif if (rc != CURLE_OK) { return rc; } } -# endif /* ENABLE_HTTP_SSL_TLS_PREVIEW */ if (ssl_options_.ssl_insecure_skip_verify) { @@ -860,7 +851,6 @@ CURLcode HttpOperation::Setup() } } else -#endif /* ENABLE_HTTP_SSL_PREVIEW */ { rc = SetCurlLongOption(CURLOPT_SSL_VERIFYPEER, 0L); if (rc != CURLE_OK) diff --git a/ext/test/http/curl_http_test.cc b/ext/test/http/curl_http_test.cc index 7c66d98b63..c51da784df 100644 --- a/ext/test/http/curl_http_test.cc +++ b/ext/test/http/curl_http_test.cc @@ -290,9 +290,7 @@ TEST_F(BasicCurlHttpTests, RequestTimeout) TEST_F(BasicCurlHttpTests, CurlHttpOperations) { -#ifdef ENABLE_HTTP_SSL_PREVIEW http_client::HttpSslOptions no_ssl; -#endif /* ENABLE_HTTP_SSL_PREVIEW */ GetEventHandler *handler = new GetEventHandler(); @@ -302,25 +300,16 @@ TEST_F(BasicCurlHttpTests, CurlHttpOperations) http_client::Headers headers = { {"name1", "value1_1"}, {"name1", "value1_2"}, {"name2", "value3"}, {"name3", "value3"}}; - curl::HttpOperation http_operations1(http_client::Method::Head, "/get", -#ifdef ENABLE_HTTP_SSL_PREVIEW - no_ssl, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ - handler, headers, body, true); + curl::HttpOperation http_operations1(http_client::Method::Head, "/get", no_ssl, handler, headers, + body, true); http_operations1.Send(); - curl::HttpOperation http_operations2(http_client::Method::Get, "/get", -#ifdef ENABLE_HTTP_SSL_PREVIEW - no_ssl, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ - handler, headers, body, true); + curl::HttpOperation http_operations2(http_client::Method::Get, "/get", no_ssl, handler, headers, + body, true); http_operations2.Send(); - curl::HttpOperation http_operations3(http_client::Method::Get, "/get", -#ifdef ENABLE_HTTP_SSL_PREVIEW - no_ssl, -#endif /* ENABLE_HTTP_SSL_PREVIEW */ - handler, headers, body, false); + curl::HttpOperation http_operations3(http_client::Method::Get, "/get", no_ssl, handler, headers, + body, false); http_operations3.Send(); delete handler; } diff --git a/functional/otlp/func_http_main.cc b/functional/otlp/func_http_main.cc index cfe12a2707..98731f1d80 100644 --- a/functional/otlp/func_http_main.cc +++ b/functional/otlp/func_http_main.cc @@ -308,7 +308,6 @@ struct test_case int test_basic(); -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW int test_cert_not_found(); int test_cert_invalid(); int test_cert_unreadable(); @@ -321,9 +320,7 @@ int test_client_key_not_found(); int test_client_key_invalid(); int test_client_key_unreadable(); int test_client_key_ok(); -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW int test_min_tls_unknown(); int test_min_tls_10(); int test_min_tls_11(); @@ -350,10 +347,8 @@ int test_range_tls_12_13(); int test_range_tls_13_10(); int test_range_tls_13_11(); int test_range_tls_13_12(); -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ static const test_case all_tests[] = {{"basic", test_basic}, -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW {"cert-not-found", test_cert_not_found}, {"cert-invalid", test_cert_invalid}, {"cert-unreadable", test_cert_unreadable}, @@ -366,9 +361,6 @@ static const test_case all_tests[] = {{"basic", test_basic}, {"client-key-invalid", test_client_key_invalid}, {"client-key-unreadable", test_client_key_unreadable}, {"client-key-ok", test_client_key_ok}, -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ - -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW {"min-tls-unknown", test_min_tls_unknown}, {"min-tls-10", test_min_tls_10}, {"min-tls-11", test_min_tls_11}, @@ -395,7 +387,6 @@ static const test_case all_tests[] = {{"basic", test_basic}, {"range-tls-13-10", test_range_tls_13_10}, {"range-tls-13-11", test_range_tls_13_11}, {"range-tls-13-12", test_range_tls_13_12}, -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ {"", nullptr}}; void list_test_cases() @@ -561,8 +552,6 @@ int test_basic() return expect_connection_failed(); } -#ifdef ENABLE_OTLP_HTTP_SSL_PREVIEW - int test_cert_not_found() { otlp::OtlpHttpExporterOptions opts; @@ -908,9 +897,6 @@ int test_client_key_ok() return expect_success(); } -#endif /* ENABLE_OTLP_HTTP_SSL_PREVIEW */ - -#ifdef ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW int test_min_tls_unknown() { @@ -1808,5 +1794,3 @@ int test_range_tls_13_12() // Impossible return expect_connection_failed(); } - -#endif /* ENABLE_OTLP_HTTP_SSL_TLS_PREVIEW */ diff --git a/test_common/include/opentelemetry/test_common/ext/http/client/nosend/http_client_nosend.h b/test_common/include/opentelemetry/test_common/ext/http/client/nosend/http_client_nosend.h index 7dddde13d4..50becac5dc 100644 --- a/test_common/include/opentelemetry/test_common/ext/http/client/nosend/http_client_nosend.h +++ b/test_common/include/opentelemetry/test_common/ext/http/client/nosend/http_client_nosend.h @@ -36,12 +36,10 @@ class Request : public opentelemetry::ext::http::client::Request method_ = method; } -#ifdef ENABLE_HTTP_SSL_PREVIEW void SetSslOptions(const HttpSslOptions &ssl_options) noexcept override { ssl_options_ = ssl_options; } -#endif /* ENABLE_HTTP_SSL_PREVIEW */ void SetBody(opentelemetry::ext::http::client::Body &body) noexcept override { @@ -65,9 +63,7 @@ class Request : public opentelemetry::ext::http::client::Request public: opentelemetry::ext::http::client::Method method_; -#ifdef ENABLE_HTTP_SSL_PREVIEW opentelemetry::ext::http::client::HttpSslOptions ssl_options_; -#endif /* ENABLE_HTTP_SSL_PREVIEW */ opentelemetry::ext::http::client::Body body_; opentelemetry::ext::http::client::Headers headers_; std::string uri_; From ab440e4d4c2e8eec7b17a14d2c5be9704a3d5a6d Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 13 Dec 2023 22:20:31 -0800 Subject: [PATCH 3/4] Bump github/codeql-action from 2 to 3 (#2452) --- .github/workflows/codeql-analysis.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 2d84fcff1c..7d6f5d2747 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -27,10 +27,10 @@ jobs: sudo -E ./ci/setup_cmake.sh sudo -E ./ci/setup_ci_environment.sh - name: Initialize CodeQL - uses: github/codeql-action/init@v2 + uses: github/codeql-action/init@v3 with: languages: cpp - name: Autobuild - uses: github/codeql-action/autobuild@v2 + uses: github/codeql-action/autobuild@v3 - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@v2 + uses: github/codeql-action/analyze@v3 From 03f2a6916d7565d11a7cd0ba5c230996279f5956 Mon Sep 17 00:00:00 2001 From: Tom Tan Date: Thu, 14 Dec 2023 12:02:12 -0800 Subject: [PATCH 4/4] [BUILD] Introduce CXX 20 CI pipeline for MSVC/Windows (#2450) --- .github/workflows/ci.yml | 16 ++++++++++++++++ CHANGELOG.md | 2 ++ api/test/nostd/string_view_test.cc | 4 ++-- api/test/nostd/variant_test.cc | 2 +- ci/do_ci.ps1 | 24 ++++++++++++++++++++++++ 5 files changed, 45 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 30b3b3fbde..cc3a4532b6 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -202,6 +202,22 @@ jobs: - name: run tests run: ./ci/do_ci.ps1 cmake.maintainer.test + cmake_msvc_maintainer_test_stl_cxx20: + name: CMake msvc (maintainer mode) with C++20 + runs-on: windows-latest + steps: + - uses: actions/checkout@v4 + with: + submodules: 'recursive' + - name: setup + run: | + ./ci/setup_windows_cmake.ps1 + ./ci/setup_windows_ci_environment.ps1 + - name: run tests + env: + CXX_STANDARD: '20' + run: ./ci/do_ci.ps1 cmake.maintainer.cxx20.stl.test + cmake_with_async_export_test: name: CMake test (without otlp-exporter and with async export) runs-on: ubuntu-latest diff --git a/CHANGELOG.md b/CHANGELOG.md index b55c3fa223..11ba426024 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,8 @@ Increment the: [#2435](https://github.com/open-telemetry/opentelemetry-cpp/pull/2435) * [BUILD] Fix removing of NOMINMAX on Windows [#2449](https://github.com/open-telemetry/opentelemetry-cpp/pull/2449) +* [BUILD] Introduce CXX 20 CI pipeline for MSVC/Windows + [#2450](https://github.com/open-telemetry/opentelemetry-cpp/pull/2450) Important changes: diff --git a/api/test/nostd/string_view_test.cc b/api/test/nostd/string_view_test.cc index 52c72ea4d8..bbd5cb0648 100644 --- a/api/test/nostd/string_view_test.cc +++ b/api/test/nostd/string_view_test.cc @@ -71,8 +71,8 @@ TEST(StringViewTest, SubstrPortion) TEST(StringViewTest, SubstrOutOfRange) { string_view s = "abc123"; -#if __EXCEPTIONS || ((defined(OPENTELEMETRY_STL_VERSION) && (OPENTELEMETRY_STL_VERSION >= 2020))) - EXPECT_THROW(s.substr(10), std::out_of_range); +#if __EXCEPTIONS || (defined(OPENTELEMETRY_STL_VERSION) && (OPENTELEMETRY_STL_VERSION >= 2017)) + EXPECT_THROW((void)s.substr(10), std::out_of_range); #else EXPECT_DEATH({ s.substr(10); }, ""); #endif diff --git a/api/test/nostd/variant_test.cc b/api/test/nostd/variant_test.cc index cea5c4ee7b..a910106390 100644 --- a/api/test/nostd/variant_test.cc +++ b/api/test/nostd/variant_test.cc @@ -48,7 +48,7 @@ TEST(VariantTest, Get) EXPECT_EQ(nostd::get(w), 12); EXPECT_EQ(*nostd::get_if(&v), 12); EXPECT_EQ(nostd::get_if(&v), nullptr); -#if __EXCEPTIONS +#if __EXCEPTIONS || (defined(OPENTELEMETRY_STL_VERSION) && (OPENTELEMETRY_STL_VERSION >= 2017)) EXPECT_THROW(nostd::get(w), nostd::bad_variant_access); #else EXPECT_DEATH({ nostd::get(w); }, ""); diff --git a/ci/do_ci.ps1 b/ci/do_ci.ps1 index 0b6cd9513e..a1e8c10014 100644 --- a/ci/do_ci.ps1 +++ b/ci/do_ci.ps1 @@ -112,6 +112,30 @@ switch ($action) { exit $exit } } + "cmake.maintainer.cxx20.stl.test" { + cd "$BUILD_DIR" + cmake $SRC_DIR ` + -DWITH_STL=CXX20 ` + -DCMAKE_CXX_STANDARD=20 ` + -DOTELCPP_MAINTAINER_MODE=ON ` + -DWITH_NO_DEPRECATED_CODE=ON ` + -DVCPKG_TARGET_TRIPLET=x64-windows ` + "-DCMAKE_TOOLCHAIN_FILE=$VCPKG_DIR/scripts/buildsystems/vcpkg.cmake" + $exit = $LASTEXITCODE + if ($exit -ne 0) { + exit $exit + } + cmake --build . -j $nproc + $exit = $LASTEXITCODE + if ($exit -ne 0) { + exit $exit + } + ctest -C Debug + $exit = $LASTEXITCODE + if ($exit -ne 0) { + exit $exit + } + } "cmake.with_async_export.test" { cd "$BUILD_DIR" cmake $SRC_DIR `