Last active
December 19, 2015 12:19
-
-
Save Ergin008/5953722 to your computer and use it in GitHub Desktop.
Javascript API Walkthrough #1 - Request Signature via 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
// | |
// 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 = "***", // the recipient (signer) name | |
templateId = "***", // valid templateId from a template in your account | |
templateRoleName = "***", // template role that exists on above template | |
baseUrl = ""; // we will retrieve this | |
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 - Request Signature via Template | |
////////////////////////////////////////////////////////////////////// | |
function(next) { | |
var url = baseUrl + "/envelopes"; | |
var body = JSON.stringify({ | |
"emailSubject": "DocuSign API call - Request Signature", | |
"templateId": templateId, | |
"templateRoles": [{ | |
"email": email, | |
"name": recipientName, | |
"roleName": templateRoleName | |
}], | |
"status": "sent" | |
}); | |
// set url, method, body, and headers | |
var options = initializeRequest(url, "POST", body, email, password); | |
// send the request... | |
request(options, function(err, res, body) { | |
parseResponseBody(err, res, body); | |
}); | |
} | |
]); | |
//*********************************************************************************************** | |
// --- 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