OAuth1Client.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. "use strict";
  2. var https = require('https'),
  3. crypto = require('crypto');
  4. var Parse = require('parse/node').Parse;
  5. var OAuth = function (options) {
  6. if (!options) {
  7. throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'No options passed to OAuth');
  8. }
  9. this.consumer_key = options.consumer_key;
  10. this.consumer_secret = options.consumer_secret;
  11. this.auth_token = options.auth_token;
  12. this.auth_token_secret = options.auth_token_secret;
  13. this.host = options.host;
  14. this.oauth_params = options.oauth_params || {};
  15. };
  16. OAuth.prototype.send = function (method, path, params, body) {
  17. var request = this.buildRequest(method, path, params, body);
  18. // Encode the body properly, the current Parse Implementation don't do it properly
  19. return new Promise(function (resolve, reject) {
  20. var httpRequest = https.request(request, function (res) {
  21. var data = '';
  22. res.on('data', function (chunk) {
  23. data += chunk;
  24. });
  25. res.on('end', function () {
  26. data = JSON.parse(data);
  27. resolve(data);
  28. });
  29. }).on('error', function () {
  30. reject('Failed to make an OAuth request');
  31. });
  32. if (request.body) {
  33. httpRequest.write(request.body);
  34. }
  35. httpRequest.end();
  36. });
  37. };
  38. OAuth.prototype.buildRequest = function (method, path, params, body) {
  39. if (path.indexOf('/') != 0) {
  40. path = '/' + path;
  41. }
  42. if (params && Object.keys(params).length > 0) {
  43. path += '?' + OAuth.buildParameterString(params);
  44. }
  45. var request = {
  46. host: this.host,
  47. path: path,
  48. method: method.toUpperCase()
  49. };
  50. var oauth_params = this.oauth_params || {};
  51. oauth_params.oauth_consumer_key = this.consumer_key;
  52. if (this.auth_token) {
  53. oauth_params['oauth_token'] = this.auth_token;
  54. }
  55. request = OAuth.signRequest(request, oauth_params, this.consumer_secret, this.auth_token_secret);
  56. if (body && Object.keys(body).length > 0) {
  57. request.body = OAuth.buildParameterString(body);
  58. }
  59. return request;
  60. };
  61. OAuth.prototype.get = function (path, params) {
  62. return this.send('GET', path, params);
  63. };
  64. OAuth.prototype.post = function (path, params, body) {
  65. return this.send('POST', path, params, body);
  66. };
  67. /*
  68. Proper string %escape encoding
  69. */
  70. OAuth.encode = function (str) {
  71. // discuss at: http://phpjs.org/functions/rawurlencode/
  72. // original by: Brett Zamir (http://brett-zamir.me)
  73. // input by: travc
  74. // input by: Brett Zamir (http://brett-zamir.me)
  75. // input by: Michael Grier
  76. // input by: Ratheous
  77. // bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  78. // bugfixed by: Brett Zamir (http://brett-zamir.me)
  79. // bugfixed by: Joris
  80. // reimplemented by: Brett Zamir (http://brett-zamir.me)
  81. // reimplemented by: Brett Zamir (http://brett-zamir.me)
  82. // note: This reflects PHP 5.3/6.0+ behavior
  83. // note: Please be aware that this function expects to encode into UTF-8 encoded strings, as found on
  84. // note: pages served as UTF-8
  85. // example 1: rawurlencode('Kevin van Zonneveld!');
  86. // returns 1: 'Kevin%20van%20Zonneveld%21'
  87. // example 2: rawurlencode('http://kevin.vanzonneveld.net/');
  88. // returns 2: 'http%3A%2F%2Fkevin.vanzonneveld.net%2F'
  89. // example 3: rawurlencode('http://www.google.nl/search?q=php.js&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:en-US:unofficial&client=firefox-a');
  90. // returns 3: 'http%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3Dphp.js%26ie%3Dutf-8%26oe%3Dutf-8%26aq%3Dt%26rls%3Dcom.ubuntu%3Aen-US%3Aunofficial%26client%3Dfirefox-a'
  91. str = (str + '').toString();
  92. // Tilde should be allowed unescaped in future versions of PHP (as reflected below), but if you want to reflect current
  93. // PHP behavior, you would need to add ".replace(/~/g, '%7E');" to the following.
  94. return encodeURIComponent(str).replace(/!/g, '%21').replace(/'/g, '%27').replace(/\(/g, '%28').replace(/\)/g, '%29').replace(/\*/g, '%2A');
  95. };
  96. OAuth.signatureMethod = 'HMAC-SHA1';
  97. OAuth.version = '1.0';
  98. /*
  99. Generate a nonce
  100. */
  101. OAuth.nonce = function () {
  102. var text = '';
  103. var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
  104. for (var i = 0; i < 30; i++) text += possible.charAt(Math.floor(Math.random() * possible.length));
  105. return text;
  106. };
  107. OAuth.buildParameterString = function (obj) {
  108. // Sort keys and encode values
  109. if (obj) {
  110. var keys = Object.keys(obj).sort();
  111. // Map key=value, join them by &
  112. return keys.map(function (key) {
  113. return key + '=' + OAuth.encode(obj[key]);
  114. }).join('&');
  115. }
  116. return '';
  117. };
  118. /*
  119. Build the signature string from the object
  120. */
  121. OAuth.buildSignatureString = function (method, url, parameters) {
  122. return [method.toUpperCase(), OAuth.encode(url), OAuth.encode(parameters)].join('&');
  123. };
  124. /*
  125. Retuns encoded HMAC-SHA1 from key and text
  126. */
  127. OAuth.signature = function (text, key) {
  128. crypto = require('crypto');
  129. return OAuth.encode(crypto.createHmac('sha1', key).update(text).digest('base64'));
  130. };
  131. OAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_token_secret) {
  132. oauth_parameters = oauth_parameters || {};
  133. // Set default values
  134. if (!oauth_parameters.oauth_nonce) {
  135. oauth_parameters.oauth_nonce = OAuth.nonce();
  136. }
  137. if (!oauth_parameters.oauth_timestamp) {
  138. oauth_parameters.oauth_timestamp = Math.floor(new Date().getTime() / 1000);
  139. }
  140. if (!oauth_parameters.oauth_signature_method) {
  141. oauth_parameters.oauth_signature_method = OAuth.signatureMethod;
  142. }
  143. if (!oauth_parameters.oauth_version) {
  144. oauth_parameters.oauth_version = OAuth.version;
  145. }
  146. if (!auth_token_secret) {
  147. auth_token_secret = '';
  148. }
  149. // Force GET method if unset
  150. if (!request.method) {
  151. request.method = 'GET';
  152. }
  153. // Collect all the parameters in one signatureParameters object
  154. var signatureParams = {};
  155. var parametersToMerge = [request.params, request.body, oauth_parameters];
  156. for (var i in parametersToMerge) {
  157. var parameters = parametersToMerge[i];
  158. for (var k in parameters) {
  159. signatureParams[k] = parameters[k];
  160. }
  161. }
  162. // Create a string based on the parameters
  163. var parameterString = OAuth.buildParameterString(signatureParams);
  164. // Build the signature string
  165. var url = 'https://' + request.host + '' + request.path;
  166. var signatureString = OAuth.buildSignatureString(request.method, url, parameterString);
  167. // Hash the signature string
  168. var signatureKey = [OAuth.encode(consumer_secret), OAuth.encode(auth_token_secret)].join('&');
  169. var signature = OAuth.signature(signatureString, signatureKey);
  170. // Set the signature in the params
  171. oauth_parameters.oauth_signature = signature;
  172. if (!request.headers) {
  173. request.headers = {};
  174. }
  175. // Set the authorization header
  176. var authHeader = Object.keys(oauth_parameters).sort().map(function (key) {
  177. var value = oauth_parameters[key];
  178. return key + '="' + value + '"';
  179. }).join(', ');
  180. request.headers.Authorization = 'OAuth ' + authHeader;
  181. // Set the content type header
  182. request.headers['Content-Type'] = 'application/x-www-form-urlencoded';
  183. return request;
  184. };
  185. module.exports = OAuth;
  186. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["https","require","crypto","Parse","OAuth","options","Error","INTERNAL_SERVER_ERROR","consumer_key","consumer_secret","auth_token","auth_token_secret","host","oauth_params","prototype","send","method","path","params","body","request","buildRequest","Promise","resolve","reject","httpRequest","res","data","on","chunk","JSON","parse","write","end","indexOf","Object","keys","length","buildParameterString","toUpperCase","oauth_consumer_key","signRequest","get","post","encode","str","toString","encodeURIComponent","replace","signatureMethod","version","nonce","text","possible","i","charAt","Math","floor","random","obj","sort","map","key","join","buildSignatureString","url","parameters","signature","createHmac","update","digest","oauth_parameters","oauth_nonce","oauth_timestamp","Date","getTime","oauth_signature_method","oauth_version","signatureParams","parametersToMerge","k","parameterString","signatureString","signatureKey","oauth_signature","headers","authHeader","value","Authorization","module","exports"],"sources":["../../../src/Adapters/Auth/OAuth1Client.js"],"sourcesContent":["var https = require('https'),\n  crypto = require('crypto');\nvar Parse = require('parse/node').Parse;\n\nvar OAuth = function (options) {\n  if (!options) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'No options passed to OAuth');\n  }\n  this.consumer_key = options.consumer_key;\n  this.consumer_secret = options.consumer_secret;\n  this.auth_token = options.auth_token;\n  this.auth_token_secret = options.auth_token_secret;\n  this.host = options.host;\n  this.oauth_params = options.oauth_params || {};\n};\n\nOAuth.prototype.send = function (method, path, params, body) {\n  var request = this.buildRequest(method, path, params, body);\n  // Encode the body properly, the current Parse Implementation don't do it properly\n  return new Promise(function (resolve, reject) {\n    var httpRequest = https\n      .request(request, function (res) {\n        var data = '';\n        res.on('data', function (chunk) {\n          data += chunk;\n        });\n        res.on('end', function () {\n          data = JSON.parse(data);\n          resolve(data);\n        });\n      })\n      .on('error', function () {\n        reject('Failed to make an OAuth request');\n      });\n    if (request.body) {\n      httpRequest.write(request.body);\n    }\n    httpRequest.end();\n  });\n};\n\nOAuth.prototype.buildRequest = function (method, path, params, body) {\n  if (path.indexOf('/') != 0) {\n    path = '/' + path;\n  }\n  if (params && Object.keys(params).length > 0) {\n    path += '?' + OAuth.buildParameterString(params);\n  }\n\n  var request = {\n    host: this.host,\n    path: path,\n    method: method.toUpperCase(),\n  };\n\n  var oauth_params = this.oauth_params || {};\n  oauth_params.oauth_consumer_key = this.consumer_key;\n  if (this.auth_token) {\n    oauth_params['oauth_token'] = this.auth_token;\n  }\n\n  request = OAuth.signRequest(request, oauth_params, this.consumer_secret, this.auth_token_secret);\n\n  if (body && Object.keys(body).length > 0) {\n    request.body = OAuth.buildParameterString(body);\n  }\n  return request;\n};\n\nOAuth.prototype.get = function (path, params) {\n  return this.send('GET', path, params);\n};\n\nOAuth.prototype.post = function (path, params, body) {\n  return this.send('POST', path, params, body);\n};\n\n/*\n\tProper string %escape encoding\n*/\nOAuth.encode = function (str) {\n  //       discuss at: http://phpjs.org/functions/rawurlencode/\n  //      original by: Brett Zamir (http://brett-zamir.me)\n  //         input by: travc\n  //         input by: Brett Zamir (http://brett-zamir.me)\n  //         input by: Michael Grier\n  //         input by: Ratheous\n  //      bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)\n  //      bugfixed by: Brett Zamir (http://brett-zamir.me)\n  //      bugfixed by: Joris\n  // reimplemented by: Brett Zamir (http://brett-zamir.me)\n  // reimplemented by: Brett Zamir (http://brett-zamir.me)\n  //             note: This reflects PHP 5.3/6.0+ behavior\n  //             note: Please be aware that this function expects to encode into UTF-8 encoded strings, as found on\n  //             note: pages served as UTF-8\n  //        example 1: rawurlencode('Kevin van Zonneveld!');\n  //        returns 1: 'Kevin%20van%20Zonneveld%21'\n  //        example 2: rawurlencode('http://kevin.vanzonneveld.net/');\n  //        returns 2: 'http%3A%2F%2Fkevin.vanzonneveld.net%2F'\n  //        example 3: rawurlencode('http://www.google.nl/search?q=php.js&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:en-US:unofficial&client=firefox-a');\n  //        returns 3: 'http%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3Dphp.js%26ie%3Dutf-8%26oe%3Dutf-8%26aq%3Dt%26rls%3Dcom.ubuntu%3Aen-US%3Aunofficial%26client%3Dfirefox-a'\n\n  str = (str + '').toString();\n\n  // Tilde should be allowed unescaped in future versions of PHP (as reflected below), but if you want to reflect current\n  // PHP behavior, you would need to add \".replace(/~/g, '%7E');\" to the following.\n  return encodeURIComponent(str)\n    .replace(/!/g, '%21')\n    .replace(/'/g, '%27')\n    .replace(/\\(/g, '%28')\n    .replace(/\\)/g, '%29')\n    .replace(/\\*/g, '%2A');\n};\n\nOAuth.signatureMethod = 'HMAC-SHA1';\nOAuth.version = '1.0';\n\n/*\n\tGenerate a nonce\n*/\nOAuth.nonce = function () {\n  var text = '';\n  var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n\n  for (var i = 0; i < 30; i++) text += possible.charAt(Math.floor(Math.random() * possible.length));\n\n  return text;\n};\n\nOAuth.buildParameterString = function (obj) {\n  // Sort keys and encode values\n  if (obj) {\n    var keys = Object.keys(obj).sort();\n\n    // Map key=value, join them by &\n    return keys\n      .map(function (key) {\n        return key + '=' + OAuth.encode(obj[key]);\n      })\n      .join('&');\n  }\n\n  return '';\n};\n\n/*\n\tBuild the signature string from the object\n*/\n\nOAuth.buildSignatureString = function (method, url, parameters) {\n  return [method.toUpperCase(), OAuth.encode(url), OAuth.encode(parameters)].join('&');\n};\n\n/*\n\tRetuns encoded HMAC-SHA1 from key and text\n*/\nOAuth.signature = function (text, key) {\n  crypto = require('crypto');\n  return OAuth.encode(crypto.createHmac('sha1', key).update(text).digest('base64'));\n};\n\nOAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_token_secret) {\n  oauth_parameters = oauth_parameters || {};\n\n  // Set default values\n  if (!oauth_parameters.oauth_nonce) {\n    oauth_parameters.oauth_nonce = OAuth.nonce();\n  }\n  if (!oauth_parameters.oauth_timestamp) {\n    oauth_parameters.oauth_timestamp = Math.floor(new Date().getTime() / 1000);\n  }\n  if (!oauth_parameters.oauth_signature_method) {\n    oauth_parameters.oauth_signature_method = OAuth.signatureMethod;\n  }\n  if (!oauth_parameters.oauth_version) {\n    oauth_parameters.oauth_version = OAuth.version;\n  }\n\n  if (!auth_token_secret) {\n    auth_token_secret = '';\n  }\n  // Force GET method if unset\n  if (!request.method) {\n    request.method = 'GET';\n  }\n\n  // Collect  all the parameters in one signatureParameters object\n  var signatureParams = {};\n  var parametersToMerge = [request.params, request.body, oauth_parameters];\n  for (var i in parametersToMerge) {\n    var parameters = parametersToMerge[i];\n    for (var k in parameters) {\n      signatureParams[k] = parameters[k];\n    }\n  }\n\n  // Create a string based on the parameters\n  var parameterString = OAuth.buildParameterString(signatureParams);\n\n  // Build the signature string\n  var url = 'https://' + request.host + '' + request.path;\n\n  var signatureString = OAuth.buildSignatureString(request.method, url, parameterString);\n  // Hash the signature string\n  var signatureKey = [OAuth.encode(consumer_secret), OAuth.encode(auth_token_secret)].join('&');\n\n  var signature = OAuth.signature(signatureString, signatureKey);\n\n  // Set the signature in the params\n  oauth_parameters.oauth_signature = signature;\n  if (!request.headers) {\n    request.headers = {};\n  }\n\n  // Set the authorization header\n  var authHeader = Object.keys(oauth_parameters)\n    .sort()\n    .map(function (key) {\n      var value = oauth_parameters[key];\n      return key + '=\"' + value + '\"';\n    })\n    .join(', ');\n\n  request.headers.Authorization = 'OAuth ' + authHeader;\n\n  // Set the content type header\n  request.headers['Content-Type'] = 'application/x-www-form-urlencoded';\n  return request;\n};\n\nmodule.exports = OAuth;\n"],"mappings":"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","ignoreList":[]}