Last active
December 20, 2015 15:59
-
-
Save Ergin008/6158318 to your computer and use it in GitHub Desktop.
DocuSign API Walkthrough - Embedded Sending (JavaScript)
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
// | |
// to run this sample | |
// 1. copy the file in your own directory - say, example.js | |
// 2. change "***" to appropriate values | |
// 3. install async and request packages | |
// npm install async | |
// npm install request | |
// 4. execute | |
// node example.js | |
// | |
var async = require("async"), // async module | |
request = require("request"), // request module | |
email = "***", // your account email | |
password = "***", // your account password | |
integratorKey = "***", // your account Integrator Key (found on Preferences -> API page) | |
recipientName = "***", // recipient (signer) name | |
templateId = "***", // provide valid templateId from a template in your account | |
templateRoleName = "***", // template role that exists on template referenced above | |
baseUrl = "", // we will retrieve this | |
envelopeId = ""; // created from step 2 | |
async.waterfall( | |
[ | |
////////////////////////////////////////////////////////////////////// | |
// Step 1 - Login (used to retrieve accountId and baseUrl) | |
////////////////////////////////////////////////////////////////////// | |
function(next) { | |
var url = "https://demo.docusign.net/restapi/v2/login_information"; | |
var body = ""; // no request body for login api call | |
// set request url, method, body, and headers | |
var options = initializeRequest(url, "GET", body, email, password); | |
// send the request... | |
request(options, function(err, res, body) { | |
if(!parseResponseBody(err, res, body)) { | |
return; | |
} | |
baseUrl = JSON.parse(body).loginAccounts[0].baseUrl; | |
next(null); // call next function | |
}); | |
}, | |
////////////////////////////////////////////////////////////////////// | |
// Step 2 - Create envelope with one recipient and save as draft | |
////////////////////////////////////////////////////////////////////// | |
function(next) { | |
var url = baseUrl + "/envelopes"; | |
var body = JSON.stringify({ | |
"emailSubject": "DocuSign API call - Embedded Sending Example", | |
"templateId": templateId, | |
"templateRoles": [{ | |
"email": email, | |
"name": recipientName, | |
"roleName": templateRoleName | |
}], | |
"status": "created" // don't send the envelope yet, just create it | |
}); | |
// set request url, method, body, and headers | |
var options = initializeRequest(url, "POST", body, email, password); | |
// send the request... | |
request(options, function(err, res, body) { | |
if(!parseResponseBody(err, res, body)) { | |
return; | |
} | |
// parse the envelopeId value from the response | |
envelopeId = JSON.parse(body).envelopeId; | |
next(null); // call next function | |
}); | |
}, | |
////////////////////////////////////////////////////////////////////// | |
// Step 3 - Get the Embedded Sending View (aka the "tag-and-send" view) | |
////////////////////////////////////////////////////////////////////// | |
function(next) { | |
var url = baseUrl + "/envelopes/" + envelopeId + "/views/sender"; | |
var body = JSON.stringify({ "returnUrl": "http://www.docusign.com/devcenter" }); | |
// set request url, method, and body | |
var options = initializeRequest(url, "POST", body, email, password); | |
// send the request... | |
request(options, function(err, res, body) { | |
if(!parseResponseBody(err, res, body)) | |
return; | |
else | |
console.log("\nNavigate to the above URL to start the Embedded Sending workflow..."); | |
}); | |
} | |
]); | |
//*********************************************************************************************** | |
// --- HELPER FUNCTIONS --- | |
//*********************************************************************************************** | |
function initializeRequest(url, method, body, email, password) { | |
var options = { | |
"method": method, | |
"uri": url, | |
"body": body, | |
"headers": {} | |
}; | |
addRequestHeaders(options, email, password); | |
return options; | |
} | |
/////////////////////////////////////////////////////////////////////////////////////////////// | |
function addRequestHeaders(options, email, password) { | |
// JSON formatted authentication header (XML format allowed as well) | |
dsAuthHeader = JSON.stringify({ | |
"Username": email, | |
"Password": password, | |
"IntegratorKey": integratorKey // global | |
}); | |
// DocuSign authorization header | |
options.headers["X-DocuSign-Authentication"] = dsAuthHeader; | |
} | |
/////////////////////////////////////////////////////////////////////////////////////////////// | |
function parseResponseBody(err, res, body) { | |
console.log("\r\nAPI Call Result: \r\n", JSON.parse(body)); | |
if( res.statusCode != 200 && res.statusCode != 201) { // success statuses | |
console.log("Error calling webservice, status is: ", res.statusCode); | |
console.log("\r\n", err); | |
return false; | |
} | |
return true; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment