Proxy Configuration Support
APIMatic’s SDKs provide native proxy support to meet enterprise requirements for network traffic routing, security monitoring, and compliance. This implementation allows seamless integration with corporate proxy infrastructures without modifying generated code.
Why Proxy Support Matters
Enterprise environments typically mandate proxy usage for:
- Security: Monitoring and filtering outgoing traffic
- Compliance: Meeting regulatory requirements for data governance
- Authentication: Corporate network access control
- Auditing: Centralized logging of API traffic
Without our built-in proxy support, you’d need to manually modify SDK code (breaking maintainability), implement complex network layer overrides, or configure system-wide proxy settings that lack granularity.
Implementation Approach
The proxy configuration leverages each language's native HTTP client capabilities for:
- Consistency across all SDKs
- Maintainability with no custom proxy handling code
- Performance through optimal routing via native implementations
- Security with proper credential handling and TLS support
Proxy Settings
| Parameter | Required | Description | 
|---|---|---|
| address | Yes | Full URL of the proxy server (example, http://proxy.corp.example.com) | 
| port | No | Port number used to connect to the proxy server | 
| auth | No | Credentials for proxy authentication (if required) | 
| tunnel | No | Enables HTTPS tunneling through proxy when true(default:false) | 
SDK Client Initialization
- PHP
- .NET
- TypeScript
- Ruby
- Python
- Java
$client = SdkClientBuilder::init()
    ->proxyConfiguration(
        ProxyConfigurationBuilder::init('http://proxy.example.com') // Address (Required)
            ->port(8080)  // Custom proxy port
            ->auth("username","password")   // Provides credentials
            ->authMethod(CURLAUTH_BASIC) // Specifies the authentication method to use
            ->tunnel(false) // Enables Http tunneling
    )
    ->build();
Supported auth methods can be found here:(libcurl authentication documentation):
var client = new SDKClient.Builder()
    .HttpClientConfig(config => config
        .Proxy(
            new ProxyConfigurationBuilder("http://localhost") // Address (Required)
                .Port(8080) // Custom proxy port
                .Tunnel(false)  // Enables Http tunneling
                .Auth("user", "pass") // Provides credentials
        )
    )
    .Build();
const client = new Client({
  httpClientOptions: {
    proxySettings: {
      address: 'http://localhost',
      port: 8080,
      auth: {
        username: 'admin',
        password: 'password123'
      }
    }
  }
});
- The TypeScript SDKs don't include a tunnel option in the proxy configuration, it's automatically handled by the underlying HTTP client when required.
- Proxy settings apply only in Node environments. If set in browsers, they're ignored and a warning is displayed.
client = Client.new(
  proxy_settings: ProxySettings.new(
    address: 'http://localhost',
    port: 8080,
    username: 'admin',
    password: 'password123'
  )
)
The Ruby SDKs don't include a tunnel option in the proxy configuration, it's automatically handled by the underlying HTTP client when required.
client = SdkClient(
    proxy_settings=ProxySettings(
        address='http://localhost',
        port=8080,
        username='admin',
        password='password123'
    )
)
The Python SDKs don't include a tunnel option in the proxy configuration, it's automatically handled by the underlying HTTP client when required.
SdkClient client = new SdkClient.Builder()
        .httpClientConfig(configBuilder -> configBuilder
                .proxyConfig(new HttpProxyConfiguration
                        .Builder("http://localhost", 8080)
                        .auth("admin", "password123")))
        .build();
The Java SDKs don't include a tunnel option in the proxy configuration, it's automatically handled by the underlying HTTP client when required.