Secure Connect for Harness Cloud
Beta Notice for Secure Connect on Harness Cloud
Secure Connect for Harness Cloud is currently in beta and may not yet be fully stable. Its functionality and performance are subject to change, and some issues may occur during use.
To enable Secure Connect for Harness Cloud, ensure the feature flag CI_SECURE_TUNNEL
is active. Please contact Harness Support for assistance with enabling this feature.
For macOS users, the additional feature flag CI_HOSTED_CONTAINERLESS_OOTB_STEP_ENABLED
is required for compatibility.
Harness CI Cloud (Harness-managed build infrastructure) addresses common challenges you might face when implementing a continuous integration tool in your infrastructure:
- Can I trust Harness CI Cloud with my intellectual property (source code, artifacts, and so on)? Yes. Harness CI Cloud doesn't retain your data after running a build.
- Can Harness CI Cloud securely connect to my complex and private firewalled infrastructure? Yes. You can use Secure Connect for Harness CI Cloud to connect to your private assets through a secure tunnel.
- Can I prove that Harness CI Cloud is secure so I can get it approved quickly by the required stakeholders (security team, ARB, DevOps platform team, infrastructure teams, and so on)? Yes. Harness CI Cloud has been penetration tested by external experts, and it is ISO and SOC2 certified. If you're already using Harness CI Cloud, additional approval isn't needed to enable Secure Connect to connect to your firewalled assets.
What is Secure Connect for Harness Cloud
With Secure Connect for Harness CI Cloud, you can connect to your sensitive assets through a secure tunnel. This allows you to use Harness Cloud build infrastructure with privately-hosted assets, such as internal artifacts repositories and on-premises code repositories. Secure Connect is a faster alternative to allowlisting IPs.
You can configure Secure Connect in minutes. If you're already using Harness Cloud build infrastructure, you don't need additional approval to enable Secure Connect.
Secure | Effective |
---|---|
|
|
Configure Secure Connect
- The client must support connection by proxy.
- Secure Connect Client is supported on macOS and Linux.
-
Create a Harness API key with at least
RBAC:core_pipeline_view
andABAC:All
permissions. -
Use the following command to run the Docker client in your firewalled environment. Where you run the client depends on what assets need to securely connect to Harness and your environment's network configuration. The client uses Basic authentication for security. If basic auth details are not provided via the following command,harness generates them using SHA256.
docker run -it -e REMOTE_PORT=ANY_PORT_FROM_30000_TO_30099 -e REMOTE_SERVER=sc.harness.io -e API_KEY=YOUR_HARNESS_API_KEY -e USER_NAME=YOUR_AUTH_USERNAME -e USER_PASSWORD=YOUR_AUTH_PASSWORD harness/frpc-signed
REMOTE_PORT
is any port from 30000 to 30099.API_KEY
is a valid Harness API key.USER_NAME
is user name used for basic authentication (optional)USER_PASSWORD
is password used for basic authentication (optional)
-
Enable Secure Connect for each connector you use with Harness Cloud that needs to route through a secure tunnel. This setting is available in each connector's Connect to Provider settings.
For example, if you need to connect to an on-premise code repo, you need to enable Secure Connect in your code repo connector's settings.
Compatible connectors include:
Use Secure Connect environment variables to route other clients
When you enable Secure Connect, Harness sets two environment variables: HARNESS_HTTP_PROXY
and HARNESS_HTTPS_PROXY
.
You can use these environment variables in cURL commands to tunnel other clients through the established secure tunnel, for example:
curl -x HARNESS_HTTPS_PROXY YOUR_ENDPOINT_URL
Replace YOUR_ENDPOINT_URL
with the URL that you want to route through the secure tunnel. For example, you could route a private Bitbucket domain like https://bitbucket.myorg.com/
.