Last active
December 8, 2021 04:55
-
-
Save Ergin008/4165604 to your computer and use it in GitHub Desktop.
Request Document Signature from Template
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// DocuSign API Walkthrough 01 in Java - Request Signature from Template | |
import java.io.*; | |
import java.net.URL; | |
import java.net.HttpURLConnection; | |
import javax.xml.transform.*; | |
import javax.xml.transform.stream.*; | |
import javax.xml.xpath.*; | |
import org.xml.sax.InputSource; | |
public class requestSignatureTemplate | |
{ | |
public static void main(String[] args) throws Exception | |
{ | |
//------------------------------------------------------------------------------------ | |
// ENTER VALUES FOR THE FOLLOWING 7 VARIABLES: | |
//------------------------------------------------------------------------------------ | |
String integratorKey = "***"; // integrator key (found on Preferences -> API page) | |
String username = "***"; // account email | |
String password = "***"; // account password | |
String templateId = "***"; // valid template id copied from Console | |
String roleName = "***"; // valid template role name | |
String recipientName = "***"; // recipient (signer) name | |
String recipientEmail = "***"; // recipient (signer) email | |
//------------------------------------------------------------------------------------ | |
// first we construct the DocuSign authentication header (can be XML or JSON format) | |
String authenticationHeader = | |
"<DocuSignCredentials>" + | |
"<Username>" + username + "</Username>" + | |
"<Password>" + password + "</Password>" + | |
"<IntegratorKey>" + integratorKey + "</IntegratorKey>" + | |
"</DocuSignCredentials>"; | |
// additional variable declarations | |
String baseURL = ""; // we will retrieve this through the Login API call | |
String accountId = ""; // we will retrieve this through the Login API call | |
String envelopeId = ""; // generated from signature request API call | |
String url = ""; // end-point for each api call | |
String body = ""; // request body | |
String response = ""; // response body | |
int status; // response status | |
HttpURLConnection connection = null; // connection object used for each request | |
//============================================================================ | |
// STEP 1 - Make the Login API call to retrieve your baseUrl and accountId | |
//============================================================================ | |
url = "https://demo.docusign.net/restapi/v2/login_information"; | |
body = ""; // no request body for the login call | |
// create connection object, set request method, add request headers | |
connection = InitializeRequest(url, "GET", body, authenticationHeader); | |
// send the request | |
System.out.println("STEP 1: Sending Login request...\n"); | |
status = connection.getResponseCode(); | |
if( status != 200 ) // 200 = OK | |
{ | |
errorParse(connection, status); | |
return; | |
} | |
// obtain baseUrl and accountId values from response body | |
response = getResponseBody(connection); | |
baseURL = parseXMLBody(response, "baseUrl"); | |
accountId = parseXMLBody(response, "accountId"); | |
System.out.println("-- Login response --\n\n" + prettyFormat(response, 2) + "\n"); | |
//============================================================================ | |
// STEP 2 - Signature Request from Template API Call | |
//============================================================================ | |
url = baseURL + "/envelopes"; // append "/envelopes" to baseUrl for signature request call | |
// this example uses XML formatted requests, JSON format is also accepted | |
body = "<envelopeDefinition xmlns=\"http://www.docusign.com/restapi\">" + | |
"<accountId>" + accountId + "</accountId>" + | |
"<status>sent</status>" + // "sent" to send envelope, "created" to save as draft envelope | |
"<emailSubject>DocuSign API Call - Signature request from template</emailSubject>" + | |
"<templateId>" + templateId + "</templateId>" + | |
"<templateRoles>" + | |
"<templateRole>" + | |
"<name>" + recipientName + "</name>" + | |
"<email>" + recipientEmail + "</email>" + | |
"<roleName>" + roleName + "</roleName>" + | |
"</templateRole>" + | |
"</templateRoles>" + | |
"</envelopeDefinition>"; | |
// re-use connection object for second request... | |
connection = InitializeRequest(url, "POST", body, authenticationHeader); | |
System.out.println("STEP 2: Sending signature request from template...\n"); | |
status = connection.getResponseCode(); // triggers the request | |
if( status != 201 ) // 201 = Created | |
{ | |
errorParse(connection, status); | |
return; | |
} | |
// obtain envelopeId value from response body | |
response = getResponseBody(connection); | |
envelopeId = parseXMLBody(response, "envelopeId"); | |
System.out.println("-- Signature Request response --\n\n" + prettyFormat(response, 2)); | |
System.out.println("Signature request has been sent to " + recipientEmail + "!\nEnvelopeId is: " + envelopeId + "\n"); | |
} //end main() | |
//*********************************************************************************************** | |
//*********************************************************************************************** | |
// --- HELPER FUNCTIONS --- | |
//*********************************************************************************************** | |
//*********************************************************************************************** | |
public static HttpURLConnection InitializeRequest(String url, String method, String body, String httpAuthHeader) { | |
HttpURLConnection conn = null; | |
try { | |
conn = (HttpURLConnection)new URL(url).openConnection(); | |
conn.setRequestMethod(method); | |
conn.setRequestProperty("X-DocuSign-Authentication", httpAuthHeader); | |
conn.setRequestProperty("Content-Type", "application/xml"); | |
conn.setRequestProperty("Accept", "application/xml"); | |
if (method.equalsIgnoreCase("POST")) | |
{ | |
conn.setRequestProperty("Content-Length", Integer.toString(body.length())); | |
conn.setDoOutput(true); | |
// write body of the POST request | |
DataOutputStream dos = new DataOutputStream( conn.getOutputStream() ); | |
dos.writeBytes(body); dos.flush(); dos.close(); | |
} | |
return conn; | |
} catch (Exception e) { | |
throw new RuntimeException(e); // simple exception handling, please review it | |
} | |
} | |
/////////////////////////////////////////////////////////////////////////////////////////////// | |
public static String parseXMLBody(String body, String searchToken) { | |
String xPathExpression; | |
try { | |
// we use xPath to parse the XML formatted response body | |
xPathExpression = String.format("//*[1]/*[local-name()='%s']", searchToken); | |
XPath xPath = XPathFactory.newInstance().newXPath(); | |
return (xPath.evaluate(xPathExpression, new InputSource(new StringReader(body)))); | |
} catch (Exception e) { | |
throw new RuntimeException(e); // simple exception handling, please review it | |
} | |
} | |
/////////////////////////////////////////////////////////////////////////////////////////////// | |
public static String getResponseBody(HttpURLConnection conn) { | |
BufferedReader br = null; | |
StringBuilder body = null; | |
String line = ""; | |
try { | |
// we use xPath to get the baseUrl and accountId from the XML response body | |
br = new BufferedReader(new InputStreamReader( conn.getInputStream())); | |
body = new StringBuilder(); | |
while ( (line = br.readLine()) != null) | |
body.append(line); | |
return body.toString(); | |
} catch (Exception e) { | |
throw new RuntimeException(e); // simple exception handling, please review it | |
} | |
} | |
/////////////////////////////////////////////////////////////////////////////////////////////// | |
public static void errorParse(HttpURLConnection conn, int status) { | |
BufferedReader br; | |
String line; | |
StringBuilder responseError; | |
try { | |
System.out.print("API call failed, status returned was: " + status); | |
InputStreamReader isr = new InputStreamReader( conn.getErrorStream() ); | |
br = new BufferedReader(isr); | |
responseError = new StringBuilder(); | |
line = null; | |
while ( (line = br.readLine()) != null) | |
responseError.append(line); | |
System.out.println("\nError description: \n" + prettyFormat(responseError.toString(), 2)); | |
return; | |
} | |
catch (Exception e) { | |
throw new RuntimeException(e); // simple exception handling, please review it | |
} | |
} | |
/////////////////////////////////////////////////////////////////////////////////////////////// | |
public static String prettyFormat(String input, int indent) { | |
try { | |
Source xmlInput = new StreamSource(new StringReader(input)); | |
StringWriter stringWriter = new StringWriter(); | |
StreamResult xmlOutput = new StreamResult(stringWriter); | |
TransformerFactory transformerFactory = TransformerFactory.newInstance(); | |
transformerFactory.setAttribute("indent-number", indent); | |
Transformer transformer = transformerFactory.newTransformer(); | |
transformer.setOutputProperty(OutputKeys.INDENT, "yes"); | |
transformer.transform(xmlInput, xmlOutput); | |
return xmlOutput.getWriter().toString(); | |
} catch (Exception e) { | |
throw new RuntimeException(e); // simple exception handling, please review it | |
} | |
} | |
} // end class |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment