From 95c9d7555b5225e5f91c433a754100eb8a4e223f Mon Sep 17 00:00:00 2001 From: Tako Schotanus Date: Tue, 24 Sep 2024 16:52:54 +0200 Subject: [PATCH] feat: proxies can now be set using HTTPS_PROXY Fixes MWTELE-42 --- .../EnvAndSysPropsInsightsConfiguration.java | 10 ++++++- .../EnvVariableConfigurationTest.java | 29 ++++++++++++++++++- 2 files changed, 37 insertions(+), 2 deletions(-) diff --git a/api/src/main/java/com/redhat/insights/config/EnvAndSysPropsInsightsConfiguration.java b/api/src/main/java/com/redhat/insights/config/EnvAndSysPropsInsightsConfiguration.java index 85feb0fb..a1596b94 100644 --- a/api/src/main/java/com/redhat/insights/config/EnvAndSysPropsInsightsConfiguration.java +++ b/api/src/main/java/com/redhat/insights/config/EnvAndSysPropsInsightsConfiguration.java @@ -4,6 +4,7 @@ import static com.redhat.insights.InsightsErrorCode.ERROR_IDENTIFICATION_NOT_DEFINED; import com.redhat.insights.InsightsException; +import java.net.URI; import java.time.Duration; import java.util.Optional; import org.jspecify.annotations.NullMarked; @@ -26,6 +27,7 @@ public class EnvAndSysPropsInsightsConfiguration extends DefaultInsightsConfigur public static final String ENV_ARCHIVE_UPLOAD_DIR = "RHT_INSIGHTS_JAVA_ARCHIVE_UPLOAD_DIR"; public static final String ENV_PROXY_HOST = "RHT_INSIGHTS_JAVA_PROXY_HOST"; public static final String ENV_PROXY_PORT = "RHT_INSIGHTS_JAVA_PROXY_PORT"; + public static final String ENV_HTTPS_PROXY = "HTTPS_PROXY"; public static final String ENV_OPT_OUT = "RHT_INSIGHTS_JAVA_OPT_OUT"; public static final String ENV_CONNECT_PERIOD = "RHT_INSIGHTS_JAVA_CONNECT_PERIOD"; public static final String ENV_UPDATE_PERIOD = "RHT_INSIGHTS_JAVA_UPDATE_PERIOD"; @@ -118,7 +120,13 @@ public Optional getProxyConfiguration() { String host = lookup(ENV_PROXY_HOST); String port = lookup(ENV_PROXY_PORT); if (host == null || port == null) { - return Optional.empty(); + String httpsProxy = lookup(ENV_HTTPS_PROXY); + if (httpsProxy == null) { + return Optional.empty(); + } + URI proxyUri = URI.create(httpsProxy); + host = proxyUri.getHost(); + port = Integer.toString(proxyUri.getPort()); } return Optional.of(new ProxyConfiguration(host, Integer.parseUnsignedInt(port))); } diff --git a/api/src/test/java/com/redhat/insights/configuration/EnvVariableConfigurationTest.java b/api/src/test/java/com/redhat/insights/configuration/EnvVariableConfigurationTest.java index 16d63259..6eb48222 100644 --- a/api/src/test/java/com/redhat/insights/configuration/EnvVariableConfigurationTest.java +++ b/api/src/test/java/com/redhat/insights/configuration/EnvVariableConfigurationTest.java @@ -1,4 +1,4 @@ -/* Copyright (C) Red Hat 2023 */ +/* Copyright (C) Red Hat 2023-2024 */ package com.redhat.insights.configuration; import static com.redhat.insights.config.EnvAndSysPropsInsightsConfiguration.*; @@ -98,6 +98,33 @@ void testGetProxyConfiguration() { "Configuration does not contain value passed through environment variable."); } + @Test + void testGetProxyConfigurationWithUnusedEnv() { + environmentVariables.set(ENV_HTTPS_PROXY, "https://env-https-proxy-host:54321"); + assertEquals( + "env-proxy-host", + config.getProxyConfiguration().get().getHost(), + "Configuration does not contain value passed through environment variable."); + assertEquals( + 12345, + config.getProxyConfiguration().get().getPort(), + "Configuration does not contain value passed through environment variable."); + } + + @Test + void testGetProxyConfigurationAlternative() { + environmentVariables.remove(ENV_PROXY_HOST).remove(ENV_PROXY_PORT); + environmentVariables.set(ENV_HTTPS_PROXY, "https://env-https-proxy-host:54321"); + assertEquals( + "env-https-proxy-host", + config.getProxyConfiguration().get().getHost(), + "Configuration does not contain value passed through environment variable."); + assertEquals( + 54321, + config.getProxyConfiguration().get().getPort(), + "Configuration does not contain value passed through environment variable."); + } + @Test void testIsOptingOut() { assertEquals(