How Tos

The samples and documentation here should get you quickly up and running with the PDF Services SDK. These code examples illustrate how to perform PDF actions using the SDK, including:

Service region configuration

Adobe PDF Services SDKs use US (United States) as a default region to process all the documents. Once you purchase PDF Services SDK, the SDKs can be configured to process the documents in a specified region that is listed below. Currently, PDF Services SDKs has support for the following regions :

Region Code
Name
US
United States (default)
EU
Europe

In addition to the details below, you can refer to working code samples:

Available properties:

Override the region property via a custom ClientConfig class:

data-slots=heading, code
data-repeat=4
data-languages=Java, .NET, Node JS, Python

Java

ClientConfig clientConfig = ClientConfig.builder()
    .setRegion(Region.EU)
    .build();

.NET

ClientConfig clientConfig = ClientConfig.ConfigBuilder()
    .SetRegion(Region.EU)
    .Build();

Node.js

const clientConfig = PDFServicesSdk.ClientConfig
    .clientConfigBuilder()
    .setRegion(Region.EU)
    .build();

Python

client_config = ClientConfig.builder()
    .with_region(Region.EU)
    .build()

Proxy Server Configuration

The Java SDK enables connection to API calls through Proxy via Client Configurations. Also, it supports username and password based authentication for the proxy server. It allows the clients to use SDK within the network where all outgoing calls have to go through a proxy and are allowed only if allow-listed on the proxy. Please refer to the following sample for details.

Java Proxy Server configuration

Available properties:

All these properties are wrapped within the proxyServerConfig object. Further, username and password is to be provided inside the nested object usernamePasswordCredentials.

Set the above properties using a custom ProxyServerConfig class, and use ClientConfig class to configure proxy server.

Sample showing proxy server configuration without authentication.

data-slots=heading, code
data-repeat=1
data-languages=Java
ProxyServerConfig proxyServerConfig = new ProxyServerConfig.Builder()
    .withHost("PROXY_HOSTNAME")
    .withProxyScheme(ProxyScheme.HTTPS)
    .withPort(443)
    .build();

ClientConfig clientConfig = ClientConfig.builder()
    .withConnectTimeout(10000)
    .withSocketTimeout(40000)
    .withProxyServerConfig(proxyServerConfig)
    .build();

Sample showing proxy server configuration with authentication.

data-slots=heading, code
data-repeat=1
data-languages=Java
ProxyServerConfig proxyServerConfig = new ProxyServerConfig.Builder()
    .withHost("PROXY_HOSTNAME")
    .withProxyScheme(ProxyScheme.HTTPS)
    .withPort(443)
    .withCredentials(new UsernamePasswordCredentials("USERNAME", "PASSWORD"))
    .build();

ClientConfig clientConfig = ClientConfig.builder()
    .withConnectTimeout(10000)
    .withSocketTimeout(40000)
    .withProxyServerConfig(proxyServerConfig)
    .build();

Custom timeout configuration

The APIs use inferred timeout properties and provide defaults. However, the SDK supports custom timeouts for the API calls. You can tailor the timeout settings for your environment and network speed. In addition to the details below, you can refer to working code samples:

Java timeout configuration

Available properties:

Override the timeout properties via a custom ClientConfig class:

data-slots=heading, code
data-repeat=1
data-languages=Java
ClientConfig clientConfig = ClientConfig.builder()
    .withConnectTimeout(3000)
    .withSocketTimeout(20000)
    .withProcessingTimeout(900000)
    .build();

.NET timeout configuration

Available properties:

Override the timeout properties via a custom ClientConfig class:

data-slots=heading, code
data-repeat=1
data-languages=.NET
ClientConfig clientConfig = ClientConfig.ConfigBuilder()
    .WithTimeout(40000)
    .WithReadWriteTimeout(10000)
    .WithProcessingTmeout(900000)
    .Build();

Node.js timeout configuration

Available properties:

Override the timeout properties via a custom ClientConfig class:

data-slots=heading, code
data-repeat=1
data-languages=Node JS
const clientConfig = PDFServicesSdk.ClientConfig
    .clientConfigBuilder()
    .withConnectTimeout(15000)
    .withReadTimeout(15000)
    .withProcessingTimeout(900000)
  .build();

Python timeout configuration

Available properties:

Override the timeout properties via a custom ClientConfig class:

data-slots=heading, code
data-repeat=1
data-languages=Python
client_config = ClientConfig.builder()
    .with_connect_timeout(10000)
    .with_read_timeout(40000)
    .build()