UNPKG

aws-api-gateway-client

Version:
291 lines (212 loc) 36.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _axios = _interopRequireDefault(require("axios")); var _axiosRetry = _interopRequireDefault(require("axios-retry")); var _sha = _interopRequireDefault(require("crypto-js/sha256")); var _encHex = _interopRequireDefault(require("crypto-js/enc-hex")); var _hmacSha = _interopRequireDefault(require("crypto-js/hmac-sha256")); var _url = _interopRequireDefault(require("url")); var _utils = _interopRequireDefault(require("./utils")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var sigV4ClientFactory = {}; sigV4ClientFactory.newClient = function (config) { var AWS_SHA_256 = 'AWS4-HMAC-SHA256'; var AWS4_REQUEST = 'aws4_request'; var AWS4 = 'AWS4'; var X_AMZ_DATE = 'x-amz-date'; var X_AMZ_SECURITY_TOKEN = 'x-amz-security-token'; var HOST = 'host'; var AUTHORIZATION = 'Authorization'; function hash(value) { return (0, _sha["default"])(value); // eslint-disable-line } function hexEncode(value) { return value.toString(_encHex["default"]); } function hmac(secret, value) { return (0, _hmacSha["default"])(value, secret, { asBytes: true }); // eslint-disable-line } function buildCanonicalRequest(method, path, queryParams, headers, payload) { return method + '\n' + buildCanonicalUri(path) + '\n' + buildCanonicalQueryString(queryParams) + '\n' + buildCanonicalHeaders(headers) + '\n' + buildCanonicalSignedHeaders(headers) + '\n' + hexEncode(hash(payload)); } function hashCanonicalRequest(request) { return hexEncode(hash(request)); } function buildCanonicalUri(uri) { return encodeURI(uri); } function buildCanonicalQueryString(queryParams) { if (Object.keys(queryParams).length < 1) { return ''; } var sortedQueryParams = []; for (var property in queryParams) { if (Object.prototype.hasOwnProperty.call(queryParams, property)) { sortedQueryParams.push(property); } } sortedQueryParams.sort(); var canonicalQueryString = ''; for (var i = 0; i < sortedQueryParams.length; i++) { canonicalQueryString += sortedQueryParams[i] + '=' + fixedEncodeURIComponent(queryParams[sortedQueryParams[i]]) + '&'; } return canonicalQueryString.substr(0, canonicalQueryString.length - 1); } function fixedEncodeURIComponent(str) { return encodeURIComponent(str).replace(/[!'()*]/g, function (c) { return '%' + c.charCodeAt(0).toString(16); }); } function buildCanonicalHeaders(headers) { var canonicalHeaders = ''; var sortedKeys = []; for (var property in headers) { if (Object.prototype.hasOwnProperty.call(headers, property)) { sortedKeys.push(property); } } sortedKeys.sort(function (a, b) { return a.toLowerCase().localeCompare(b.toLowerCase()); }); for (var i = 0; i < sortedKeys.length; i++) { canonicalHeaders += sortedKeys[i].toLowerCase() + ':' + headers[sortedKeys[i]] + '\n'; } return canonicalHeaders; } function buildCanonicalSignedHeaders(headers) { var sortedKeys = []; for (var property in headers) { if (Object.prototype.hasOwnProperty.call(headers, property)) { sortedKeys.push(property.toLowerCase()); } } sortedKeys.sort(); return sortedKeys.join(';'); } function buildStringToSign(datetime, credentialScope, hashedCanonicalRequest) { return AWS_SHA_256 + '\n' + datetime + '\n' + credentialScope + '\n' + hashedCanonicalRequest; } function buildCredentialScope(datetime, region, service) { return datetime.substr(0, 8) + '/' + region + '/' + service + '/' + AWS4_REQUEST; } function calculateSigningKey(secretKey, datetime, region, service) { return hmac(hmac(hmac(hmac(AWS4 + secretKey, datetime.substr(0, 8)), region), service), AWS4_REQUEST); } function calculateSignature(key, stringToSign) { return hexEncode(hmac(key, stringToSign)); } function buildAuthorizationHeader(accessKey, credentialScope, headers, signature) { return AWS_SHA_256 + ' Credential=' + accessKey + '/' + credentialScope + ', SignedHeaders=' + buildCanonicalSignedHeaders(headers) + ', Signature=' + signature; } var awsSigV4Client = {}; if (config.accessKey === undefined || config.secretKey === undefined) { return awsSigV4Client; } awsSigV4Client.accessKey = _utils["default"].assertDefined(config.accessKey, 'accessKey'); awsSigV4Client.secretKey = _utils["default"].assertDefined(config.secretKey, 'secretKey'); awsSigV4Client.sessionToken = config.sessionToken; awsSigV4Client.serviceName = _utils["default"].assertDefined(config.serviceName, 'serviceName'); awsSigV4Client.region = _utils["default"].assertDefined(config.region, 'region'); awsSigV4Client.endpoint = _utils["default"].assertDefined(config.endpoint, 'endpoint'); awsSigV4Client.retries = config.retries; awsSigV4Client.retryCondition = config.retryCondition; awsSigV4Client.retryDelay = config.retryDelay; awsSigV4Client.host = config.host; awsSigV4Client.makeRequest = function (request) { var verb = _utils["default"].assertDefined(request.verb, 'verb'); var path = _utils["default"].assertDefined(request.path, 'path'); var queryParams = _utils["default"].copy(request.queryParams); var timeout = _utils["default"].copy(request.timeout); if (queryParams === undefined) { queryParams = {}; } if (timeout === undefined) { timeout = 0; } var headers = _utils["default"].copy(request.headers); if (headers === undefined) { headers = {}; } // If the user has not specified an override for Content type the use default if (headers['Content-Type'] === undefined) { headers['Content-Type'] = config.defaultContentType; } // If the user has not specified an override for Accept type the use default if (headers['Accept'] === undefined) { headers['Accept'] = config.defaultAcceptType; } var body = _utils["default"].copy(request.body); // stringify request body if content type is JSON if (body && headers['Content-Type'] && headers['Content-Type'] === 'application/json') { body = JSON.stringify(body); } // If there is no body remove the content-type header so it is not included in SigV4 calculation if (body === '' || body === undefined || body === null) { delete headers['Content-Type']; } var datetime = new Date(new Date().getTime() + config.systemClockOffset).toISOString().replace(/\.\d{3}Z$/, 'Z').replace(/[:-]|\.\d{3}/g, ''); headers[X_AMZ_DATE] = datetime; if (awsSigV4Client.host) { headers[HOST] = awsSigV4Client.host; } else { var parser = _url["default"].parse(awsSigV4Client.endpoint); headers[HOST] = parser.hostname; } var canonicalRequest = buildCanonicalRequest(verb, path, queryParams, headers, body); var hashedCanonicalRequest = hashCanonicalRequest(canonicalRequest); var credentialScope = buildCredentialScope(datetime, awsSigV4Client.region, awsSigV4Client.serviceName); var stringToSign = buildStringToSign(datetime, credentialScope, hashedCanonicalRequest); var signingKey = calculateSigningKey(awsSigV4Client.secretKey, datetime, awsSigV4Client.region, awsSigV4Client.serviceName); var signature = calculateSignature(signingKey, stringToSign); headers[AUTHORIZATION] = buildAuthorizationHeader(awsSigV4Client.accessKey, credentialScope, headers, signature); if (awsSigV4Client.sessionToken !== undefined && awsSigV4Client.sessionToken !== '') { headers[X_AMZ_SECURITY_TOKEN] = awsSigV4Client.sessionToken; } delete headers[HOST]; var url = config.endpoint + path; var queryString = buildCanonicalQueryString(queryParams); if (queryString !== '') { url += '?' + queryString; } // Need to re-attach Content-Type if it is not specified at this point if (headers['Content-Type'] === undefined) { headers['Content-Type'] = config.defaultContentType; } var signedRequest = { headers: headers, timeout: timeout, data: body, method: verb, url: url }; if (config.retries !== undefined) { signedRequest.baseURL = url; var client = _axios["default"].create(signedRequest); // Allow user configurable delay, or built-in exponential delay var retryDelay = function retryDelay() { return 0; }; if (config.retryDelay === 'exponential') { retryDelay = _axiosRetry["default"].exponentialDelay; } else if (typeof config.retryDelay === 'number') { retryDelay = function retryDelay() { return parseInt(config.retryDelay); }; } else if (typeof config.retryDelay === 'function') { retryDelay = config.retryDelay; } (0, _axiosRetry["default"])(client, _objectSpread(_objectSpread({}, config), {}, { retryCondition: config.retryCondition, retryDelay: retryDelay })); return client.request(signedRequest); } return (0, _axios["default"])(signedRequest); }; return awsSigV4Client; }; var _default = sigV4ClientFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/lib/apiGatewayCore/sigV4Client.js"],"names":["sigV4ClientFactory","newClient","config","AWS_SHA_256","AWS4_REQUEST","AWS4","X_AMZ_DATE","X_AMZ_SECURITY_TOKEN","HOST","AUTHORIZATION","hash","value","hexEncode","toString","encHex","hmac","secret","asBytes","buildCanonicalRequest","method","path","queryParams","headers","payload","buildCanonicalUri","buildCanonicalQueryString","buildCanonicalHeaders","buildCanonicalSignedHeaders","hashCanonicalRequest","request","uri","encodeURI","Object","keys","length","sortedQueryParams","property","prototype","hasOwnProperty","call","push","sort","canonicalQueryString","i","fixedEncodeURIComponent","substr","str","encodeURIComponent","replace","c","charCodeAt","canonicalHeaders","sortedKeys","a","b","toLowerCase","localeCompare","join","buildStringToSign","datetime","credentialScope","hashedCanonicalRequest","buildCredentialScope","region","service","calculateSigningKey","secretKey","calculateSignature","key","stringToSign","buildAuthorizationHeader","accessKey","signature","awsSigV4Client","undefined","utils","assertDefined","sessionToken","serviceName","endpoint","retries","retryCondition","retryDelay","host","makeRequest","verb","copy","timeout","defaultContentType","defaultAcceptType","body","JSON","stringify","Date","getTime","systemClockOffset","toISOString","parser","urlParser","parse","hostname","canonicalRequest","signingKey","url","queryString","signedRequest","data","baseURL","client","axios","create","axiosRetry","exponentialDelay","parseInt"],"mappings":"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","sourcesContent":["/*\n * Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\").\n * You may not use this file except in compliance with the License.\n * A copy of the License is located at\n *\n *  http://aws.amazon.com/apache2.0\n *\n * or in the \"license\" file accompanying this file. This file is distributed\n * on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either\n * express or implied. See the License for the specific language governing\n * permissions and limitations under the License.\n */\n\nimport axios from 'axios';\nimport axiosRetry from 'axios-retry';\nimport SHA256 from 'crypto-js/sha256';\nimport encHex from 'crypto-js/enc-hex';\nimport HmacSHA256 from 'crypto-js/hmac-sha256';\nimport urlParser from 'url';\nimport utils from './utils';\n\nconst sigV4ClientFactory = {};\nsigV4ClientFactory.newClient = function(config) {\n  let AWS_SHA_256 = 'AWS4-HMAC-SHA256';\n  let AWS4_REQUEST = 'aws4_request';\n  let AWS4 = 'AWS4';\n  let X_AMZ_DATE = 'x-amz-date';\n  let X_AMZ_SECURITY_TOKEN = 'x-amz-security-token';\n  let HOST = 'host';\n  let AUTHORIZATION = 'Authorization';\n\n  function hash(value) {\n    return SHA256(value); // eslint-disable-line\n  }\n\n  function hexEncode(value) {\n    return value.toString(encHex);\n  }\n\n  function hmac(secret, value) {\n    return HmacSHA256(value, secret, {asBytes: true}); // eslint-disable-line\n  }\n\n  function buildCanonicalRequest(method, path, queryParams, headers, payload) {\n    return method + '\\n' +\n      buildCanonicalUri(path) + '\\n' +\n      buildCanonicalQueryString(queryParams) + '\\n' +\n      buildCanonicalHeaders(headers) + '\\n' +\n      buildCanonicalSignedHeaders(headers) + '\\n' +\n      hexEncode(hash(payload));\n  }\n\n  function hashCanonicalRequest(request) {\n    return hexEncode(hash(request));\n  }\n\n  function buildCanonicalUri(uri) {\n    return encodeURI(uri);\n  }\n\n  function buildCanonicalQueryString(queryParams) {\n    if (Object.keys(queryParams).length < 1) {\n      return '';\n    }\n\n    let sortedQueryParams = [];\n    for (let property in queryParams) {\n      if (Object.prototype.hasOwnProperty.call(queryParams, property)) {\n        sortedQueryParams.push(property);\n      }\n    }\n    sortedQueryParams.sort();\n\n    let canonicalQueryString = '';\n    for (let i = 0; i < sortedQueryParams.length; i++) {\n      canonicalQueryString += sortedQueryParams[i]\n        + '=' + fixedEncodeURIComponent(queryParams[sortedQueryParams[i]]) + '&';\n    }\n    return canonicalQueryString.substr(0, canonicalQueryString.length - 1);\n  }\n\n  function fixedEncodeURIComponent(str) {\n    return encodeURIComponent(str).replace(/[!'()*]/g, function(c) {\n      return '%' + c.charCodeAt(0).toString(16);\n    });\n  }\n\n  function buildCanonicalHeaders(headers) {\n    let canonicalHeaders = '';\n    let sortedKeys = [];\n    for (let property in headers) {\n      if (Object.prototype.hasOwnProperty.call(headers, property)) {\n        sortedKeys.push(property);\n      }\n    }\n    sortedKeys.sort((a, b) => a.toLowerCase().localeCompare(b.toLowerCase()));\n\n    for (let i = 0; i < sortedKeys.length; i++) {\n      canonicalHeaders += sortedKeys[i].toLowerCase() + ':' + headers[sortedKeys[i]] + '\\n';\n    }\n    return canonicalHeaders;\n  }\n\n  function buildCanonicalSignedHeaders(headers) {\n    let sortedKeys = [];\n    for (let property in headers) {\n      if (Object.prototype.hasOwnProperty.call(headers, property)) {\n        sortedKeys.push(property.toLowerCase());\n      }\n    }\n    sortedKeys.sort();\n\n    return sortedKeys.join(';');\n  }\n\n  function buildStringToSign(datetime, credentialScope, hashedCanonicalRequest) {\n    return AWS_SHA_256 + '\\n' +\n      datetime + '\\n' +\n      credentialScope + '\\n' +\n      hashedCanonicalRequest;\n  }\n\n  function buildCredentialScope(datetime, region, service) {\n    return datetime.substr(0, 8) + '/' + region + '/' + service + '/' + AWS4_REQUEST;\n  }\n\n  function calculateSigningKey(secretKey, datetime, region, service) {\n    return hmac(hmac(hmac(\n      hmac(AWS4 + secretKey, datetime.substr(0, 8)),\n      region\n    ), service), AWS4_REQUEST);\n  }\n\n  function calculateSignature(key, stringToSign) {\n    return hexEncode(hmac(key, stringToSign));\n  }\n\n  function buildAuthorizationHeader(accessKey, credentialScope, headers, signature) {\n    return AWS_SHA_256 + ' Credential=' + accessKey + '/' + credentialScope\n      + ', SignedHeaders=' + buildCanonicalSignedHeaders(headers) + ', Signature=' + signature;\n  }\n\n  let awsSigV4Client = { };\n  if (config.accessKey === undefined || config.secretKey === undefined) {\n    return awsSigV4Client;\n  }\n  awsSigV4Client.accessKey = utils.assertDefined(config.accessKey, 'accessKey');\n  awsSigV4Client.secretKey = utils.assertDefined(config.secretKey, 'secretKey');\n  awsSigV4Client.sessionToken = config.sessionToken;\n  awsSigV4Client.serviceName = utils.assertDefined(config.serviceName, 'serviceName');\n  awsSigV4Client.region = utils.assertDefined(config.region, 'region');\n  awsSigV4Client.endpoint = utils.assertDefined(config.endpoint, 'endpoint');\n  awsSigV4Client.retries = config.retries;\n  awsSigV4Client.retryCondition = config.retryCondition;\n  awsSigV4Client.retryDelay = config.retryDelay;\n  awsSigV4Client.host = config.host;\n\n  awsSigV4Client.makeRequest = function(request) {\n    let verb = utils.assertDefined(request.verb, 'verb');\n    let path = utils.assertDefined(request.path, 'path');\n    let queryParams = utils.copy(request.queryParams);\n    let timeout = utils.copy(request.timeout);\n\n    if (queryParams === undefined) {\n      queryParams = {};\n    }\n\n    if (timeout === undefined) {\n      timeout = 0;\n    }\n    let headers = utils.copy(request.headers);\n    if (headers === undefined) {\n      headers = {};\n    }\n\n    // If the user has not specified an override for Content type the use default\n    if (headers['Content-Type'] === undefined) {\n      headers['Content-Type'] = config.defaultContentType;\n    }\n\n    // If the user has not specified an override for Accept type the use default\n    if (headers['Accept'] === undefined) {\n      headers['Accept'] = config.defaultAcceptType;\n    }\n\n    let body = utils.copy(request.body);\n\n    // stringify request body if content type is JSON\n    if (body && headers['Content-Type'] && headers['Content-Type'] === 'application/json') {\n      body = JSON.stringify(body);\n    }\n\n    // If there is no body remove the content-type header so it is not included in SigV4 calculation\n    if (body === '' || body === undefined || body === null) {\n      delete headers['Content-Type'];\n    }\n\n    let datetime = new Date(new Date().getTime() + config.systemClockOffset).toISOString()\n                   .replace(/\\.\\d{3}Z$/, 'Z').replace(/[:-]|\\.\\d{3}/g, '');\n    headers[X_AMZ_DATE] = datetime;\n\n    if (awsSigV4Client.host) {\n      headers[HOST] = awsSigV4Client.host;\n    } else {\n      let parser = urlParser.parse(awsSigV4Client.endpoint);\n      headers[HOST] = parser.hostname;\n    }\n\n    let canonicalRequest = buildCanonicalRequest(verb, path, queryParams, headers, body);\n    let hashedCanonicalRequest = hashCanonicalRequest(canonicalRequest);\n    let credentialScope = buildCredentialScope(\n      datetime,\n      awsSigV4Client.region,\n      awsSigV4Client.serviceName\n    );\n    let stringToSign = buildStringToSign(datetime, credentialScope, hashedCanonicalRequest);\n    let signingKey = calculateSigningKey(\n      awsSigV4Client.secretKey,\n      datetime,\n      awsSigV4Client.region,\n      awsSigV4Client.serviceName\n    );\n    let signature = calculateSignature(signingKey, stringToSign);\n    headers[AUTHORIZATION] = buildAuthorizationHeader(\n      awsSigV4Client.accessKey,\n      credentialScope,\n      headers,\n      signature\n    );\n    if (awsSigV4Client.sessionToken !== undefined && awsSigV4Client.sessionToken !== '') {\n      headers[X_AMZ_SECURITY_TOKEN] = awsSigV4Client.sessionToken;\n    }\n    delete headers[HOST];\n\n    let url = config.endpoint + path;\n    let queryString = buildCanonicalQueryString(queryParams);\n    if (queryString !== '') {\n      url += '?' + queryString;\n    }\n\n    // Need to re-attach Content-Type if it is not specified at this point\n    if (headers['Content-Type'] === undefined) {\n      headers['Content-Type'] = config.defaultContentType;\n    }\n\n    let signedRequest = {\n      headers: headers,\n      timeout: timeout,\n      data: body,\n      method: verb,\n      url,\n    };\n    if (config.retries !== undefined) {\n      signedRequest.baseURL = url;\n      let client = axios.create(signedRequest);\n\n      // Allow user configurable delay, or built-in exponential delay\n      let retryDelay = () => 0;\n      if (config.retryDelay === 'exponential') {\n        retryDelay = axiosRetry.exponentialDelay;\n      } else if (typeof config.retryDelay === 'number') {\n        retryDelay = () => parseInt(config.retryDelay);\n      } else if (typeof config.retryDelay === 'function') {\n        retryDelay = config.retryDelay;\n      }\n\n      axiosRetry(client, {\n        ...config,\n        retryCondition: config.retryCondition,\n        retryDelay,\n      });\n      return client.request(signedRequest);\n    }\n\n    return axios(signedRequest);\n  };\n\n  return awsSigV4Client;\n};\n\nexport default sigV4ClientFactory;\n"]}