Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions contract-tests/client-contract-tests/src/entity_manager.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,15 @@ std::optional<std::string> EntityManager::create(ConfigParams const& in) {
config_builder.HttpProperties().Tls(std::move(builder));
}

if (in.wrapper) {
if (!in.wrapper->name.empty()) {
config_builder.HttpProperties().WrapperName(in.wrapper->name);
}
if (!in.wrapper->version.empty()) {
config_builder.HttpProperties().WrapperVersion(in.wrapper->version);
}
}

auto config = config_builder.Build();
if (!config) {
LD_LOG(logger_, LogLevel::kWarn)
Expand Down
1 change: 1 addition & 0 deletions contract-tests/client-contract-tests/src/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ int main(int argc, char* argv[]) {
srv.add_capability("tls:skip-verify-peer");
srv.add_capability("tls:custom-ca");
srv.add_capability("client-prereq-events");
srv.add_capability("wrapper");
// Proxies are supported only with CURL networking.
#ifdef LD_CURL_NETWORKING
srv.add_capability("http-proxy");
Expand Down
11 changes: 10 additions & 1 deletion contract-tests/data-model/include/data_model/data_model.hpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
#pragma once

#include <optional>
Expand Down Expand Up @@ -143,6 +143,13 @@

NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE_WITH_DEFAULT(ConfigHooksParams, hooks);

struct ConfigWrapper {
std::string name;
std::string version;
};

NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE_WITH_DEFAULT(ConfigWrapper, name, version);

struct ConfigParams {
std::string credential;
std::optional<uint32_t> startWaitTimeMs;
Expand All @@ -156,6 +163,7 @@
std::optional<ConfigTLSParams> tls;
std::optional<ConfigProxyParams> proxy;
std::optional<ConfigHooksParams> hooks;
std::optional<ConfigWrapper> wrapper;
};

NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE_WITH_DEFAULT(ConfigParams,
Expand All @@ -170,7 +178,8 @@
tags,
tls,
proxy,
hooks);
hooks,
wrapper);

struct ContextSingleParams {
std::optional<std::string> kind;
Expand Down
9 changes: 9 additions & 0 deletions contract-tests/server-contract-tests/src/entity_manager.cpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
#include "entity_manager.hpp"
#include "contract_test_hook.hpp"

Expand Down Expand Up @@ -145,6 +145,15 @@
}
}

if (in.wrapper) {
if (!in.wrapper->name.empty()) {
config_builder.HttpProperties().WrapperName(in.wrapper->name);
}
if (!in.wrapper->version.empty()) {
config_builder.HttpProperties().WrapperVersion(in.wrapper->version);
}
}

auto config = config_builder.Build();
if (!config) {
LD_LOG(logger_, LogLevel::kWarn)
Expand Down
1 change: 1 addition & 0 deletions contract-tests/server-contract-tests/src/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ int main(int argc, char* argv[]) {
srv.add_capability("client-prereq-events");
srv.add_capability("evaluation-hooks");
srv.add_capability("track-hooks");
srv.add_capability("wrapper");

net::signal_set signals{ioc, SIGINT, SIGTERM};

Expand Down
8 changes: 6 additions & 2 deletions libs/common/src/config/http_properties_builder.cpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
#include <utility>

#include <launchdarkly/config/shared/builders/http_properties_builder.hpp>
Expand Down Expand Up @@ -133,8 +133,12 @@
built::HttpProperties HttpPropertiesBuilder<SDK>::Build() const {
if (!wrapper_name_.empty()) {
std::map<std::string, std::string> headers_with_wrapper(base_headers_);
headers_with_wrapper["X-LaunchDarkly-Wrapper"] =
wrapper_name_ + "/" + wrapper_version_;
if (wrapper_version_.empty()) {
headers_with_wrapper["X-LaunchDarkly-Wrapper"] = wrapper_name_;
} else {
headers_with_wrapper["X-LaunchDarkly-Wrapper"] =
wrapper_name_ + "/" + wrapper_version_;
}
return {connect_timeout_, read_timeout_, write_timeout_,
response_timeout_, headers_with_wrapper, tls_.Build(), proxy_};
}
Expand Down
Loading