com.dynamicpdf.api.PdfInfo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dynamicpdf-api Show documentation
Show all versions of dynamicpdf-api Show documentation
A Java Client API that uses the DynamicPDF Cloud API to create, merge, split, form fill, stamp, secure/encrypt PDF documents.
The newest version!
package com.dynamicpdf.api;
import java.util.UUID;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;
import io.restassured.RestAssured;
import io.restassured.response.Response;
import io.restassured.specification.RequestSpecification;
/**
* Represents the pdf info endpoint.
*/
public class PdfInfo extends Endpoint
{
private PdfResource resource;
/**
* Initializes a new instance of the PdfInfo
class.
* @param resource The resource of type PdfResource
.
*/
public PdfInfo(PdfResource resource)
{
this.resource = resource;
}
public String getEndpointName() { return "pdf-info";}
/**
* Process the pdf resource to get pdf's information.
* @return collection of PdfInfoResponse
as multithreading tasks Task
.
*/
public PdfInfoResponse process()
{
CompletableFuture cf = processAsync();
try {
return cf.get();
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
}
return null;
}
/**
* Process the pdf resource to get pdf's information.
*
* @return collection of PdfInfoResponse
as multithreading tasks CompletableFuture
.
*/
public CompletableFuture processAsync()
{
return CompletableFuture.supplyAsync(() -> {
PdfInfoResponse pdfInfoResponse = null;
RequestSpecification requestSpec = super.createRequestSpecification();
Response response = RestAssured
.given()
.header("Accept", "application/pdf")
.header("content-type", "application/pdf")
.spec(requestSpec)
.body(resource.getData())
.post(getDefaultBaseUrl() + "/"+ getEndpointVersion() + "/" + getEndpointName());
if (response.getStatusCode() == 200)
{
pdfInfoResponse = new PdfInfoResponse(response.asString());
pdfInfoResponse.setIsSuccessful(true);
pdfInfoResponse.setStatusCode(response.getStatusCode());
}
else
{
if (response.getStatusCode() == 401) {
throw new EndpointException("Invalid api key specified.");
}
pdfInfoResponse = new PdfInfoResponse();
String errorMessage = response.jsonPath().getString("message");
UUID errorId = response.jsonPath().getUUID("id");
pdfInfoResponse.setErrorId(errorId);
pdfInfoResponse.setErrorJson(response.asString());
pdfInfoResponse.setErrorMessage(errorMessage);
pdfInfoResponse.setIsSuccessful(false);
pdfInfoResponse.setStatusCode(response.getStatusCode());
}
return pdfInfoResponse;
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy