Edit in GitHubLog an issue

Getting Started

The API is accessible through SDKs which help you get up and running quickly. Once you've received your developer credential, download and set up one of the sample projects. After you're familiar with the APIs, leverage the samples in your own server-side code.

Step 1: Procure Digital Certificate Credentials

  1. A client must register with a Trust Service Provider (TSP) and obtain the digital certificate. A certificate may be purchased from any of the supported TSPs which are Cloud Signature Consortium (CSC) compliant. For more details, see CSC standard.
  2. TSP performs remote identity verification of the client who acts as the legal owner of the digital certificate.
  3. After identity verification, the TSP issues a digital certificate to the client with a credential_id, client_id and client_secret. These are typically protected by a static PIN. The client should securely store the credential details and PIN for later use.

TSP Token Generation

Step 2: (OPTIONAL) Procure Timestamping URL and Credentials

  1. Client can register themselves with a Timestamping Authority (TSA) of their choice to include a trusted timestamp while performing eSeal operation on a document. Client will need the TSA URL along with optional username and password to use this feature.
  2. The supported TSAs are listed here. If support for any other TSA is required, reach out to us through customer support.

Step 3: Obtain your TSP OAuth Token

The client sends the client_id and client_secret to the TSP's OAuth 2.0 authorization API. The TSP responds with an access token which is passed as one of the input parameters to the PDF Electronic Seal API. The purpose of this token is to access the TSP's end points for the sealing process. It is valid during a timeframe specified by the TSP.

TSP Token Generation

Sample OAuth Request

Copied to your clipboard
curl --location --request POST 'https://<base-url>/<API-domain-name>/csc/v0/oauth2/token'
--header 'cache-control: no-cache'
--header 'content-type: application/json'
--data-raw '{
"lang": "en-US",
"client_id": "<YOUR_CLIENT_ID>",
"client_secret": "<YOUR_CLIENT_SECRET>",
"grant_type": "client_credentials"
}'

Sample Response

Copied to your clipboard
{
"access_token": "xxxx-xxx-xxx-xxxx-xxxxxxxx",
"token_type": "Bearer",
"expires_in": <TIME_IN_SECONDS>
}

Once the customer has all the necessary prerequisites in place, they have to call the PDF Electronic Seal API with the appropriate parameters to get the electronically sealed PDF.

Seal Workflow

Step 4 : Getting the API access token

PDF Electronic Seal API endpoints are authenticated endpoints. Getting an access token is a two-step process :

  1. Get Credentials - Invoking PDF Services API requires an Adobe-provided credential. To get one, click here, and complete the workflow. Be sure to copy and save the credential values to a secure location.
  2. Retrieve Access Token - The PDF Services APIs require an access_token to authorize the request. Use the "Get AccessToken" API from the Postman Collection with your client_id, client_secret (mentioned in the pdfservices-api-credentials.json file downloaded in 1) to get the access_token OR directly use the below mentioned cURL to get the access_token.
Copied to your clipboard
curl --location 'https://pdf-services.adobe.io/token' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--data-urlencode 'client_id={{Placeholder for Client ID}}' \
--data-urlencode 'client_secret={{Placeholder for Client Secret}}'

Step 5 : Uploading an asset

After getting the access token, we need to upload the asset. Uploading an asset is a two-step process :

  1. First you need to get an upload pre-signed URI by using the following API.

You can read more about the API in detail here.

Copied to your clipboard
curl --location --request POST 'https://pdf-services.adobe.io/assets' \
--header 'X-API-Key: {{Placeholder for client_id}}' \
--header 'Authorization: Bearer {{Placeholder for token}}' \
--header 'Content-Type: application/json' \
--data-raw '{
"mediaType": "{{Placeholder for mediaType}}"
}'
  1. On getting a 200 response status from the above API, use the uploadUri field in the response body of the above API to upload the asset directly to the cloud provider using a PUT API call. You will also get an assetID field which will be used in creating the job.
Copied to your clipboard
curl --location -g --request PUT 'https://dcplatformstorageservice-prod-us-east-1.s3-accelerate.amazonaws.com/b37fd583-1ab6-4f49-99ef-d716180b5de4?X-Amz-Security-Token={{Placeholder for X-Amz-Security-Token}}&X-Amz-Algorithm={{Placeholder for X-Amz-Algorithm}}&X-Amz-Date={{Placeholder for X-Amz-Date}}&X-Amz-SignedHeaders={{Placeholder for X-Amz-SignedHeaders}}&X-Amz-Expires={{Placeholder for X-Amz-Expires}}&X-Amz-Credential={{Placeholder for X-Amz-Credential}}&X-Amz-Signature={{Placeholder for X-Amz-Signature}}' \
--header 'Content-Type: application/pdf' \
--data-binary '@{{Placeholder for file path}}'

Step 6 : Creating the job

To create a job for the operation, please use the assetID obtained in Step 2 in the API request body. On successful job submission you will get a status code of 201 and a response header location which will be used for polling.

For creating the job, please refer to the corresponding API spec for the particular PDF Operation.

Step 7 : Fetching the status

Once the job is successfully created, you need to poll the at the location returned in response header of Step 3 by using the following API

You can read more about the API in detail here.

Copied to your clipboard
curl --location -g --request GET 'https://pdf-services.adobe.io/operation/electronicseal/{{Placeholder for job id}}/status' \
--header 'Authorization: Bearer {{Placeholder for token}}' \
--header 'x-api-key: {{Placeholder for client id}}'

Step 8 : Downloading the asset

On getting 200 response code from the poll API, you will receive a status field in the response body which can either be in progress, done or failed.

If the status field is in progress you need to keep polling the location until it changes to done or failed.

If the status field is done the response body will also have a download pre-signed URI in the dowloadUri field, which will be used to download the asset directly from cloud provider by making the following API call

You can read more about the API in detail here.

Copied to your clipboard
curl --location -g --request GET 'https://dcplatformstorageservice-prod-us-east-1.s3-accelerate.amazonaws.com/b37fd583-1ab6-4f49-99ef-d716180b5de4?X-Amz-Security-Token={{Placeholder for X-Amz-Security-Token}}&X-Amz-Algorithm={{Placeholder for X-Amz-Algorithm}}&X-Amz-Date={{Placeholder for X-Amz-Date}}&X-Amz-SignedHeaders={{Placeholder for X-Amz-SignedHeaders}}&X-Amz-Expires={{Placeholder for X-Amz-Expires}}&X-Amz-Credential={{Placeholder for X-Amz-Credential}}&X-Amz-Signature={{Placeholder for X-Amz-Signature}}'

There you go! Your job is completed in 8 simple steps.

SDK

PDF Services API is also accessible via SDKs in popular languages such as Node.js, Java and .NET.

Java

Jump start your development by bookmarking or downloading the following key resources:

Authentication

Once you complete the Getting Credentials, a zip or json file automatically downloads that contains content whose structure varies based on whether you opted to download personalized code samples.

  • Personalized Download: Downloads the zip which contains adobe-dc-pdf-services-sdk-java-samples with a preconfigured pdfservices-api-credentials.json file.
  • Non Personalized Download: Downloads the pdfservices-api-credentials.json with your preconfigured credentials.

After downloading the zip, you can run the samples in the zip directly by setting up the two environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following cammands :

  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>

Example pdfservices-api-credentials.json file

Copied to your clipboard
{
"client_credentials": {
"client_id": "<YOUR_CLIENT_ID>",
"client_secret": "<YOUR_CLIENT_SECRET>"
},
"service_principal_credentials": {
"organization_id": "<YOUR_ORGNIZATION_ID>"
}
}

Setup a Java environment

  1. Install Java 8 or above.
  2. Run javac -version to verify your install.
  3. Verify the JDK bin folder is included in the PATH variable (method varies by OS).
  4. Install Maven. You may use your preferred tool; for example:
  • Windows: Example: Chocolatey.
  • Macintosh: Example: brew install maven.
Running the samples

The quickest way to get up and running is to download the code samples during the Getting Credentials workflow. These samples provide everything from ready-to-run sample code, an embedded credential json file, and pre-configured connections to dependencies.

  1. Download the Java sample project.
  2. Build the sample project with Maven: mvn clean install.
  3. Set the environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following commands :
  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  1. Test the sample code on the command line.
  2. Refer to this document for details about running samples as well as the API Reference for API details.

Verifying download authenticity

For security reasons you may wish to confirm the installer's authenticity. To do so,

  1. After installing the package, navigate to the .jar.sha1 file.
  2. Calculate the hash with any 3rd party utility.
  3. Find and open PDF Services sha1 file. Note: if you're using Maven, look in the .m2 directory.
  4. Verify the hash you generated matches the value in the .sha1 file.
Copied to your clipboard
c0bc2ec0eb15dd43d014bd885b3833539f103cf2

Logging

Refer to the API docs for error and exception details.

  • For logging, use the slf4j API with a log4js-slf4j binding.
  • Logging configurations are provided in src/main/resources/log4js.properties.
  • Specify alternate bindings, if required, in pom.xml.

log4js.properties file

Copied to your clipboard
name=PropertiesConfig
appenders = console
# A sample console appender configuration, Clients can change as per their logging implementation
rootLogger.level = WARN
rootLogger.appenderRefs = stdout
rootLogger.appenderRef.stdout.ref = STDOUT
appender.console.type = Console
appender.console.name = STDOUT
appender.console.layout.type = PatternLayout
appender.console.layout.pattern = [%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
loggers = pdfservicessdk,validator,apache
# Change the logging levels as per need. INFO is recommended for pdfservices-sdk
logger.pdfservicessdk.name = com.adobe.pdfservices.operation
logger.pdfservicessdk.level = INFO
logger.pdfservicessdk.additivity = false
logger.pdfservicessdk.appenderRef.console.ref = STDOUT
logger.validator.name=org.hibernate
logger.validator.level=WARN
logger.apache.name=org.apache
logger.apache.level=WARN

Samples directory structure Java

Custom projects

While the samples use Maven, you can use your own tools and process.

To build a custom project:

  1. Access the .jar in the central Maven repository.
  2. Use your preferred dependency management tool (Ivy, Gradle, Maven), to include the SDK .jar dependency.
  3. Open the pdfservices-api-credentials.json downloaded when you created your credential.
  4. Add the Authentication details as described above.

Adobe PDF Services SDK On Maven

.NET

Jumpstart your development by bookmarking or downloading the following key resources:

Prerequisites

The samples project requires the following:

  • NET: version 6.0 or above
  • A build Tool: Either Visual Studio or .NET Core CLI.

Authentication

Once you complete the Getting Credentials, a zip or json file automatically downloads that contains content whose structure varies based on whether you opted to download personalized code samples.

  • Personalized Download: Downloads the zip which contains adobe-dc-pdf-services-sdk-java-samples with a preconfigured pdfservices-api-credentials.json file.
  • Non Personalized Download: Downloads the pdfservices-api-credentials.json with your preconfigured credentials.

After downloading the zip, you can run the samples in the zip directly by setting up the two environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following cammands :

  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>

Example pdfservices-api-credentials.json file

Copied to your clipboard
{
"client_credentials": {
"client_id": "<YOUR_CLIENT_ID>",
"client_secret": "<YOUR_CLIENT_SECRET>"
},
"service_principal_credentials": {
"organization_id": "<YOUR_ORGNIZATION_ID>"
}
}

Set up a NET environment

Running any sample or custom code requires the following:

  1. Download and install the .NET SDK.
Running the samples

The quickest way to get up and running is to download the code samples during the Getting Credentials workflow. These samples provide everything from ready-to-run sample code, an embedded credential json file, and pre-configured connections to dependencies.

  1. Clone or download the samples project.
  2. From the samples directory, build the sample project: dotnet build.
  3. Set the environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following commands :
  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  1. Test the sample code on the command line.
  2. Refer to this document for details about running samples as well as the API Reference for API details.

Verifying download authenticity

For security reasons you may wish to confirm the installer's authenticity. To do so,

  1. After installing the Nuget package, navigate to the .nuget directory.
  2. Find and open the .sha512 file.
  3. Verify the hash in the downloaded file matches the value published here.
Copied to your clipboard
jdTK6PDvEcfTai7D3N97pd0u/XrvnlEJCqTRPKDrb02zcGzaVdX/2Of3WrHOqqWUFsg7GO3yf5cKXJDFN0kdMw==

Logging

Refer to the API docs for error and exception details.

The .NET SDK uses LibLog as a bridge between different logging frameworks. Log4net is used as a logging provider in the sample projects and the logging configurations are provided in log4net.config. Add the configuration for your preferred provider and set up the necessary appender as required to enable logging.

log4net.config file

Copied to your clipboard
<log4net>
<root>
<level value="INFO" />
<appender-ref ref="console" />
</root>
<appender name="console" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %level %logger - %message%newline" />
</layout>
</appender>
</log4net>

Custom projects

While building the sample project automatically downloads the Nuget package, you can do it manually if you wish to use your own tools and process.

  1. Go to https://www.adobe.com/go/pdftoolsapi_net_nuget.
  2. Download the latest package.

Adobe PDF Services SDK on Nuget

Node.js

Jumpstart your development by bookmarking or downloading the following key resources:

Authentication

Once you complete the Getting Credentials, a zip or json file automatically downloads that contains content whose structure varies based on whether you opted to download personalized code samples.

  • Personalized Download: Downloads the zip which contains adobe-dc-pdf-services-sdk-java-samples with a preconfigured pdfservices-api-credentials.json file.
  • Non Personalized Download: Downloads the pdfservices-api-credentials.json with your preconfigured credentials.

After downloading the zip, you can run the samples in the zip directly by setting up the two environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following cammands :

  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>

Example pdfservices-api-credentials.json file

Copied to your clipboard
{
"client_credentials": {
"client_id": "<YOUR_CLIENT_ID>",
"client_secret": "<YOUR_CLIENT_SECRET>"
},
"service_principal_credentials": {
"organization_id": "<YOUR_ORGNIZATION_ID>"
}
}

Set up a Node.js environment

Running any sample or custom code requires the following steps:

  1. Install Node.js 14.0 or higher.
Copied to your clipboard
npm install --save @adobe/pdfservices-node-sdk
Running the samples

The quickest way to get up and running is to download the code samples during the Getting Credentials workflow. These samples provide everything from ready-to-run sample code, an embedded credential json file, and pre-configured connections to dependencies.

  1. Download the Node.js sample project .
  2. From the samples root directory, run npm install.
  3. Set the environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following commands :
  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  1. Test the sample code on the command line.
  2. Refer to this document for details about running samples as well as the API Reference for API details.

Verifying download authenticity

For security reasons you may wish to confirm the installer's authenticity. To do so,

  1. After installing the package, find and open package.json.
  2. Find the "_integrity" key.
  3. Verify the hash in the downloaded file matches the value published here.
Copied to your clipboard
sha512-QFwmKkeFTvZhHXrklJOUbjCx8V6FftBC+DAsMCy7Q9vy5sPXQtO47rjAt6R7nzzcA/uUPfuw4/gCFNh7yRKKRQ==

Logging

Refer to the API docs for error and exception details.

The SDK uses the log4js API for logging. During execution, the SDK searches for config/pdfservices-sdk-log4js-config.json in the working directory and reads the logging properties from there. If you do not provide a configuration file, the default logging logs INFO to the console. Customize the logging settings as needed.

log4js.properties file

Copied to your clipboard
{
"appenders": {
"consoleAppender": {
"_comment": "A sample console appender configuration, Clients can change as per their logging implementation",
"type": "console",
"layout": {
"type": "pattern",
"pattern": "%d:[%p]: %m"
}
}
},
"categories": {
"default": {
"appenders": ["consoleAppender"],
"_comment": "Change the logging levels as per need. info is recommended for pdfservices-node-sdk",
"level": "info"
}
}
}

Custom projects

While building the sample project automatically downloads the Node package, you can do it manually if you wish to use your own tools and process.

  1. Go to https://www.npmjs.com/package/@adobe/pdfservices-node-sdk
  2. Download the latest package.

Adobe PDF Services SDK on NPM JS

Public API

PDF Services API is accessible directly via REST APIs which requires Adobe-provided credential for authentication. Once you've completed the Getting Credentials workflow, a zip file automatically downloads that contains content whose structure varies based on whether you opted to download personalized code samples. The zip file structures are as follows:

  • Personalized Download: Downloads the zip which contains adobe-dc-pdf-services-sdk-java-samples with a preconfigured pdfservices-api-credentials.json file.
  • Non Personalized Download: Downloads the pdfservices-api-credentials.json with your preconfigured credentials.

After downloading the zip, you can run the samples in the zip directly by setting up the two environment variables PDF_SERVICES_CLIENT_ID and PDF_SERVICES_CLIENT_SECRET by running the following cammands :

  • Windows:

    • set PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • set PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>
  • MacOS/Linux:

    • export PDF_SERVICES_CLIENT_ID=<YOUR CLIENT ID>
    • export PDF_SERVICES_CLIENT_SECRET=<YOUR CLIENT SECRET>

Example pdfservices-api-credentials.json file

Copied to your clipboard
{
"client_credentials": {
"client_id": "<YOUR_CLIENT_ID>",
"client_secret": "<YOUR_CLIENT_SECRET>"
},
"service_principal_credentials": {
"organization_id": "<YOUR_ORGNIZATION_ID>"
}
}
  • Privacy
  • Terms of Use
  • Do not sell or share my personal information
  • AdChoices
Copyright © 2025 Adobe. All rights reserved.