UNPKG

37.9 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
8
9function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
10
11var https = require("https");
12var http = require("http");
13var request = require("request");
14var querystring = require("querystring");
15
16var HttpClient = function () {
17 function HttpClient(options, credentials) {
18 _classCallCheck(this, HttpClient);
19
20 this.credentials = credentials;
21 this.host = options.host || "rest.nexmo.com";
22 this.port = options.port || 443;
23 this.https = options.https || https;
24 this.http = options.http || http;
25 this.headers = {
26 "Content-Type": "application/x-www-form-urlencoded",
27 Accept: "application/json"
28 };
29 this.logger = options.logger;
30 this.timeout = options.timeout;
31 this.requestLib = request;
32
33 if (options.userAgent) {
34 this.headers["User-Agent"] = options.userAgent;
35 }
36 }
37
38 _createClass(HttpClient, [{
39 key: "request",
40 value: function request(endpoint, method, callback) {
41 var _this = this;
42
43 var skipJsonParsing = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
44
45 if (typeof method === "function") {
46 callback = method;
47 endpoint.method = endpoint.method || "GET";
48 } else if (typeof method !== "undefined") {
49 endpoint.method = method;
50 }
51
52 if (endpoint.method === "POST" || endpoint.method === "DELETE") {
53 // TODO: verify the following fix is required
54 // Fix broken due ot 411 Content-Length error now sent by Nexmo API
55 // PL 2016-Sept-6 - commented out Content-Length 0
56 // headers['Content-Length'] = 0;
57 }
58 var options = {
59 host: endpoint.host ? endpoint.host : this.host,
60 port: this.port,
61 path: endpoint.path,
62 method: endpoint.method,
63 headers: Object.assign({}, this.headers)
64 };
65
66 if (this.timeout !== undefined) {
67 options.timeout = this.timeout;
68 }
69
70 // Allow existing headers to be overridden
71 // Allow new headers to be added
72 if (endpoint.headers) {
73 Object.keys(endpoint.headers).forEach(function (key) {
74 options.headers[key] = endpoint.headers[key];
75 });
76 }
77
78 this.logger.info("Request:", options, "\nBody:", endpoint.body);
79 var request;
80
81 if (options.port === 443) {
82 request = this.https.request(options);
83 } else {
84 request = this.http.request(options);
85 }
86
87 request.end(endpoint.body);
88
89 // Keep an array of String or Buffers,
90 // depending on content type (binary or JSON) of response
91 var responseData = [];
92
93 request.on("response", function (response) {
94 var isBinary = response.headers["content-type"] === "application/octet-stream";
95 if (!isBinary) {
96 response.setEncoding("utf8");
97 }
98
99 response.on("data", function (chunk) {
100 responseData.push(chunk);
101 });
102
103 response.on("end", function () {
104 _this.logger.info("response ended:", response.statusCode);
105 if (callback) {
106 if (isBinary) {
107 responseData = Buffer.concat(responseData);
108 }
109
110 _this.__parseResponse(response, responseData, endpoint.method, callback, skipJsonParsing);
111 }
112 });
113 response.on("close", function (e) {
114 if (e) {
115 _this.logger.error("problem with API request detailed stacktrace below ");
116 _this.logger.error(e);
117 callback(e);
118 }
119 });
120 });
121 request.on("error", function (e) {
122 _this.logger.error("problem with API request detailed stacktrace below ");
123 _this.logger.error(e);
124 callback(e);
125 });
126 }
127 }, {
128 key: "__parseResponse",
129 value: function __parseResponse(httpResponse, data, method, callback, skipJsonParsing) {
130 var isArrayOrBuffer = data instanceof Array || data instanceof Buffer;
131 if (!isArrayOrBuffer) {
132 throw new Error("data should be of type Array or Buffer");
133 }
134
135 var status = httpResponse.statusCode;
136 var headers = httpResponse.headers;
137
138 var response = null;
139 var error = null;
140
141 try {
142 if (status >= 500) {
143 error = { message: "Server Error", statusCode: status };
144 } else if (httpResponse.headers["content-type"] === "application/octet-stream") {
145 response = data;
146 } else if (status === 429) {
147 // 429 does not return a parsable body
148 if (!headers["retry-after"]) {
149 // retry based on allowed per second
150 var retryAfterMillis = method === "POST" ? 1000 / 2 : 1000 / 5;
151 headers["retry-after"] = retryAfterMillis;
152 }
153 error = { body: data.join("") };
154 } else if (status === 204) {
155 response = null;
156 } else if (status >= 400 || status < 200) {
157 error = { body: JSON.parse(data.join("")), headers: headers };
158 } else if (method !== "DELETE") {
159 if (!!skipJsonParsing) {
160 response = data.join("");
161 } else {
162 response = JSON.parse(data.join(""));
163 }
164 } else {
165 response = data;
166 }
167 } catch (parseError) {
168 this.logger.error(parseError);
169 this.logger.error("could not convert API response to JSON, above error is ignored and raw API response is returned to client");
170 this.logger.error("Raw Error message from API ");
171 this.logger.error("\"" + data + "\"");
172
173 error = {
174 status: status,
175 message: "The API response could not be parsed.",
176 body: data.join(""),
177 parseError: parseError
178 };
179 }
180
181 if (error) {
182 error.statusCode = status;
183 error.headers = headers;
184 }
185
186 if (typeof callback === "function") {
187 callback(error, response);
188 }
189 }
190 }, {
191 key: "_addLimitedAccessMessageToErrors",
192 value: function _addLimitedAccessMessageToErrors(callback, limitedAccessStatus) {
193 return function (err, data) {
194 if (err && err.status == limitedAccessStatus) {
195 err._INFO_ = "This endpoint may need activating on your account. Please email support@nexmo.com for more information";
196 }
197
198 return callback(err, data);
199 };
200 }
201 }, {
202 key: "get",
203 value: function get(path, params, callback) {
204 var useJwt = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
205 var useBasicAuth = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
206
207 if (!callback) {
208 if (typeof params == "function") {
209 callback = params;
210 params = {};
211 }
212 }
213
214 params = params || {};
215 if (!useJwt && !useBasicAuth) {
216 params["api_key"] = this.credentials.apiKey;
217 params["api_secret"] = this.credentials.apiSecret;
218 }
219
220 path = path + "?" + querystring.stringify(params);
221
222 var headers = { "Content-Type": "application/json" };
223 if (useJwt) {
224 headers["Authorization"] = "Bearer " + this.credentials.generateJwt();
225 }
226 if (useBasicAuth) {
227 headers["Authorization"] = "Basic " + Buffer.from(this.credentials.apiKey + ":" + this.credentials.apiSecret).toString("base64");
228 }
229
230 this.request({ path: path, headers: headers }, "GET", callback);
231 }
232 }, {
233 key: "delete",
234 value: function _delete(path, callback, useJwt, useBasicAuth) {
235 var params = {};
236 if (!useJwt && !useBasicAuth) {
237 params["api_key"] = this.credentials.apiKey;
238 params["api_secret"] = this.credentials.apiSecret;
239 }
240
241 var headers = {};
242
243 if (useBasicAuth) {
244 headers["Authorization"] = "Basic " + Buffer.from(this.credentials.apiKey + ":" + this.credentials.apiSecret).toString("base64");
245 }
246 path = path + "?" + querystring.stringify(params);
247
248 this.request({ path: path, headers: headers }, "DELETE", callback);
249 }
250 }, {
251 key: "postFile",
252 value: function postFile(path, options, callback, useJwt) {
253 var qs = {};
254 if (!useJwt) {
255 qs["api_key"] = this.credentials.apiKey;
256 qs["api_secret"] = this.credentials.apiSecret;
257 }
258
259 if (Object.keys(qs).length) {
260 var joinChar = "?";
261 if (path.indexOf(joinChar) !== -1) {
262 joinChar = "&";
263 }
264 path = path + joinChar + querystring.stringify(qs);
265 }
266
267 var file = options.file;
268 delete options.file; // We don't send this as metadata
269
270 var formData = {};
271
272 if (file) {
273 formData["filedata"] = {
274 value: file,
275 options: {
276 filename: options.filename || null
277 }
278 };
279 }
280
281 if (options.info) {
282 formData.info = JSON.stringify(options.info);
283 }
284
285 if (options.url) {
286 formData.url = options.url;
287 }
288
289 this.requestLib.post({
290 url: "https://" + this.host + path,
291 formData: formData,
292 headers: {
293 Authorization: "Bearer " + this.credentials.generateJwt()
294 }
295 }, callback);
296 }
297 }, {
298 key: "post",
299 value: function post(path, params, callback, useJwt) {
300 var qs = {};
301 if (!useJwt) {
302 qs["api_key"] = this.credentials.apiKey;
303 qs["api_secret"] = this.credentials.apiSecret;
304 }
305
306 var joinChar = "?";
307 if (path.indexOf(joinChar) !== -1) {
308 joinChar = "&";
309 }
310
311 path = path + joinChar + querystring.stringify(qs);
312
313 this.request({ path: path, body: querystring.stringify(params) }, "POST", callback);
314 }
315 }, {
316 key: "postJson",
317 value: function postJson(path, params, callback, useJwt, useBasicAuth) {
318 var qs = {};
319 if (!useJwt && !useBasicAuth) {
320 qs["api_key"] = this.credentials.apiKey;
321 qs["api_secret"] = this.credentials.apiSecret;
322 }
323
324 var joinChar = "?";
325 if (path.indexOf(joinChar) !== -1) {
326 joinChar = "&";
327 }
328
329 path = path + joinChar + querystring.stringify(qs);
330
331 var headers = { "Content-Type": "application/json" };
332 if (useBasicAuth) {
333 headers["Authorization"] = "Basic " + Buffer.from(this.credentials.apiKey + ":" + this.credentials.apiSecret).toString("base64");
334 }
335
336 this.request({
337 path: path,
338 body: JSON.stringify(params),
339 headers: headers
340 }, "POST", callback);
341 }
342 }, {
343 key: "postUseQueryString",
344 value: function postUseQueryString(path, params, callback, useJwt) {
345 params = params || {};
346 if (!useJwt) {
347 params["api_key"] = this.credentials.apiKey;
348 params["api_secret"] = this.credentials.apiSecret;
349 }
350
351 path = path + "?" + querystring.stringify(params);
352
353 this.request({ path: path }, "POST", callback);
354 }
355 }]);
356
357 return HttpClient;
358}();
359
360exports.default = HttpClient;
361module.exports = exports["default"];
362//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/HttpClient.js"],"names":["https","require","http","request","querystring","HttpClient","options","credentials","host","port","headers","Accept","logger","timeout","requestLib","userAgent","endpoint","method","callback","skipJsonParsing","path","Object","assign","undefined","keys","forEach","key","info","body","end","responseData","on","isBinary","response","setEncoding","push","chunk","statusCode","Buffer","concat","__parseResponse","e","error","httpResponse","data","isArrayOrBuffer","Array","Error","status","message","retryAfterMillis","join","JSON","parse","parseError","limitedAccessStatus","err","_INFO_","params","useJwt","useBasicAuth","apiKey","apiSecret","stringify","generateJwt","from","toString","qs","length","joinChar","indexOf","file","formData","value","filename","url","post","Authorization"],"mappings":"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","file":"HttpClient.js","sourcesContent":["var https = require(\"https\");\nvar http = require(\"http\");\nvar request = require(\"request\");\nvar querystring = require(\"querystring\");\n\nclass HttpClient {\n  constructor(options, credentials) {\n    this.credentials = credentials;\n    this.host = options.host || \"rest.nexmo.com\";\n    this.port = options.port || 443;\n    this.https = options.https || https;\n    this.http = options.http || http;\n    this.headers = {\n      \"Content-Type\": \"application/x-www-form-urlencoded\",\n      Accept: \"application/json\"\n    };\n    this.logger = options.logger;\n    this.timeout = options.timeout;\n    this.requestLib = request;\n\n    if (options.userAgent) {\n      this.headers[\"User-Agent\"] = options.userAgent;\n    }\n  }\n\n  request(endpoint, method, callback, skipJsonParsing = false) {\n    if (typeof method === \"function\") {\n      callback = method;\n      endpoint.method = endpoint.method || \"GET\";\n    } else if (typeof method !== \"undefined\") {\n      endpoint.method = method;\n    }\n\n    if (endpoint.method === \"POST\" || endpoint.method === \"DELETE\") {\n      // TODO: verify the following fix is required\n      // Fix broken due ot 411 Content-Length error now sent by Nexmo API\n      // PL 2016-Sept-6 - commented out Content-Length 0\n      // headers['Content-Length'] = 0;\n    }\n    var options = {\n      host: endpoint.host ? endpoint.host : this.host,\n      port: this.port,\n      path: endpoint.path,\n      method: endpoint.method,\n      headers: Object.assign({}, this.headers)\n    };\n\n    if (this.timeout !== undefined) {\n      options.timeout = this.timeout;\n    }\n\n    // Allow existing headers to be overridden\n    // Allow new headers to be added\n    if (endpoint.headers) {\n      Object.keys(endpoint.headers).forEach(function(key) {\n        options.headers[key] = endpoint.headers[key];\n      });\n    }\n\n    this.logger.info(\"Request:\", options, \"\\nBody:\", endpoint.body);\n    var request;\n\n    if (options.port === 443) {\n      request = this.https.request(options);\n    } else {\n      request = this.http.request(options);\n    }\n\n    request.end(endpoint.body);\n\n    // Keep an array of String or Buffers,\n    // depending on content type (binary or JSON) of response\n    var responseData = [];\n\n    request.on(\"response\", response => {\n      var isBinary =\n        response.headers[\"content-type\"] === \"application/octet-stream\";\n      if (!isBinary) {\n        response.setEncoding(\"utf8\");\n      }\n\n      response.on(\"data\", chunk => {\n        responseData.push(chunk);\n      });\n\n      response.on(\"end\", () => {\n        this.logger.info(\"response ended:\", response.statusCode);\n        if (callback) {\n          if (isBinary) {\n            responseData = Buffer.concat(responseData);\n          }\n\n          this.__parseResponse(\n            response,\n            responseData,\n            endpoint.method,\n            callback,\n            skipJsonParsing\n          );\n        }\n      });\n      response.on(\"close\", e => {\n        if (e) {\n          this.logger.error(\n            \"problem with API request detailed stacktrace below \"\n          );\n          this.logger.error(e);\n          callback(e);\n        }\n      });\n    });\n    request.on(\"error\", e => {\n      this.logger.error(\"problem with API request detailed stacktrace below \");\n      this.logger.error(e);\n      callback(e);\n    });\n  }\n\n  __parseResponse(httpResponse, data, method, callback, skipJsonParsing) {\n    const isArrayOrBuffer = data instanceof Array || data instanceof Buffer;\n    if (!isArrayOrBuffer) {\n      throw new Error(\"data should be of type Array or Buffer\");\n    }\n\n    const status = httpResponse.statusCode;\n    const headers = httpResponse.headers;\n\n    let response = null;\n    var error = null;\n\n    try {\n      if (status >= 500) {\n        error = { message: \"Server Error\", statusCode: status };\n      } else if (\n        httpResponse.headers[\"content-type\"] === \"application/octet-stream\"\n      ) {\n        response = data;\n      } else if (status === 429) {\n        // 429 does not return a parsable body\n        if (!headers[\"retry-after\"]) {\n          // retry based on allowed per second\n          const retryAfterMillis = method === \"POST\" ? 1000 / 2 : 1000 / 5;\n          headers[\"retry-after\"] = retryAfterMillis;\n        }\n        error = { body: data.join(\"\") };\n      } else if (status === 204) {\n        response = null;\n      } else if (status >= 400 || status < 200) {\n        error = { body: JSON.parse(data.join(\"\")), headers };\n      } else if (method !== \"DELETE\") {\n        if (!!skipJsonParsing) {\n          response = data.join(\"\");\n        } else {\n          response = JSON.parse(data.join(\"\"));\n        }\n      } else {\n        response = data;\n      }\n    } catch (parseError) {\n      this.logger.error(parseError);\n      this.logger.error(\n        \"could not convert API response to JSON, above error is ignored and raw API response is returned to client\"\n      );\n      this.logger.error(\"Raw Error message from API \");\n      this.logger.error(`\"${data}\"`);\n\n      error = {\n        status: status,\n        message: \"The API response could not be parsed.\",\n        body: data.join(\"\"),\n        parseError: parseError\n      };\n    }\n\n    if (error) {\n      error.statusCode = status;\n      error.headers = headers;\n    }\n\n    if (typeof callback === \"function\") {\n      callback(error, response);\n    }\n  }\n\n  _addLimitedAccessMessageToErrors(callback, limitedAccessStatus) {\n    return function(err, data) {\n      if (err && err.status == limitedAccessStatus) {\n        err._INFO_ =\n          \"This endpoint may need activating on your account. Please email support@nexmo.com for more information\";\n      }\n\n      return callback(err, data);\n    };\n  }\n\n  get(path, params, callback, useJwt = false, useBasicAuth = false) {\n    if (!callback) {\n      if (typeof params == \"function\") {\n        callback = params;\n        params = {};\n      }\n    }\n\n    params = params || {};\n    if (!useJwt && !useBasicAuth) {\n      params[\"api_key\"] = this.credentials.apiKey;\n      params[\"api_secret\"] = this.credentials.apiSecret;\n    }\n\n    path = path + \"?\" + querystring.stringify(params);\n\n    const headers = { \"Content-Type\": \"application/json\" };\n    if (useJwt) {\n      headers[\"Authorization\"] = `Bearer ${this.credentials.generateJwt()}`;\n    }\n    if (useBasicAuth) {\n      headers[\"Authorization\"] = `Basic ${Buffer.from(\n        this.credentials.apiKey + \":\" + this.credentials.apiSecret\n      ).toString(\"base64\")}`;\n    }\n\n    this.request({ path: path, headers }, \"GET\", callback);\n  }\n\n  delete(path, callback, useJwt, useBasicAuth) {\n    let params = {};\n    if (!useJwt && !useBasicAuth) {\n      params[\"api_key\"] = this.credentials.apiKey;\n      params[\"api_secret\"] = this.credentials.apiSecret;\n    }\n\n    let headers = {};\n\n    if (useBasicAuth) {\n      headers[\"Authorization\"] = `Basic ${Buffer.from(\n        this.credentials.apiKey + \":\" + this.credentials.apiSecret\n      ).toString(\"base64\")}`;\n    }\n    path = path + \"?\" + querystring.stringify(params);\n\n    this.request({ path: path, headers }, \"DELETE\", callback);\n  }\n\n  postFile(path, options, callback, useJwt) {\n    let qs = {};\n    if (!useJwt) {\n      qs[\"api_key\"] = this.credentials.apiKey;\n      qs[\"api_secret\"] = this.credentials.apiSecret;\n    }\n\n    if (Object.keys(qs).length) {\n      let joinChar = \"?\";\n      if (path.indexOf(joinChar) !== -1) {\n        joinChar = \"&\";\n      }\n      path = path + joinChar + querystring.stringify(qs);\n    }\n\n    const file = options.file;\n    delete options.file; // We don't send this as metadata\n\n    const formData = {};\n\n    if (file) {\n      formData[\"filedata\"] = {\n        value: file,\n        options: {\n          filename: options.filename || null\n        }\n      };\n    }\n\n    if (options.info) {\n      formData.info = JSON.stringify(options.info);\n    }\n\n    if (options.url) {\n      formData.url = options.url;\n    }\n\n    this.requestLib.post(\n      {\n        url: \"https://\" + this.host + path,\n        formData: formData,\n        headers: {\n          Authorization: `Bearer ${this.credentials.generateJwt()}`\n        }\n      },\n      callback\n    );\n  }\n\n  post(path, params, callback, useJwt) {\n    let qs = {};\n    if (!useJwt) {\n      qs[\"api_key\"] = this.credentials.apiKey;\n      qs[\"api_secret\"] = this.credentials.apiSecret;\n    }\n\n    let joinChar = \"?\";\n    if (path.indexOf(joinChar) !== -1) {\n      joinChar = \"&\";\n    }\n\n    path = path + joinChar + querystring.stringify(qs);\n\n    this.request(\n      { path: path, body: querystring.stringify(params) },\n      \"POST\",\n      callback\n    );\n  }\n\n  postJson(path, params, callback, useJwt, useBasicAuth) {\n    let qs = {};\n    if (!useJwt && !useBasicAuth) {\n      qs[\"api_key\"] = this.credentials.apiKey;\n      qs[\"api_secret\"] = this.credentials.apiSecret;\n    }\n\n    let joinChar = \"?\";\n    if (path.indexOf(joinChar) !== -1) {\n      joinChar = \"&\";\n    }\n\n    path = path + joinChar + querystring.stringify(qs);\n\n    let headers = { \"Content-Type\": \"application/json\" };\n    if (useBasicAuth) {\n      headers[\"Authorization\"] = `Basic ${Buffer.from(\n        this.credentials.apiKey + \":\" + this.credentials.apiSecret\n      ).toString(\"base64\")}`;\n    }\n\n    this.request(\n      {\n        path: path,\n        body: JSON.stringify(params),\n        headers\n      },\n      \"POST\",\n      callback\n    );\n  }\n\n  postUseQueryString(path, params, callback, useJwt) {\n    params = params || {};\n    if (!useJwt) {\n      params[\"api_key\"] = this.credentials.apiKey;\n      params[\"api_secret\"] = this.credentials.apiSecret;\n    }\n\n    path = path + \"?\" + querystring.stringify(params);\n\n    this.request({ path: path }, \"POST\", callback);\n  }\n}\n\nexport default HttpClient;\n"]}
\No newline at end of file