1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 |
|
7 | var _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 |
|
9 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
10 |
|
11 | var https = require("https");
|
12 | var http = require("http");
|
13 | var request = require("request");
|
14 | var querystring = require("querystring");
|
15 |
|
16 | var 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 | var customResponseParser = arguments[4];
|
45 |
|
46 | if (typeof method === "function") {
|
47 | callback = method;
|
48 | endpoint.method = endpoint.method || "GET";
|
49 | } else if (typeof method !== "undefined") {
|
50 | endpoint.method = method;
|
51 | }
|
52 |
|
53 | if (endpoint.method === "POST" || endpoint.method === "DELETE") {
|
54 | // TODO: verify the following fix is required
|
55 | // Fix broken due ot 411 Content-Length error now sent by Nexmo API
|
56 | // PL 2016-Sept-6 - commented out Content-Length 0
|
57 | // headers['Content-Length'] = 0;
|
58 | }
|
59 | var options = {
|
60 | host: endpoint.host ? endpoint.host : this.host,
|
61 | port: this.port,
|
62 | path: endpoint.path,
|
63 | method: endpoint.method,
|
64 | headers: Object.assign({}, this.headers)
|
65 | };
|
66 |
|
67 | if (this.timeout !== undefined) {
|
68 | options.timeout = this.timeout;
|
69 | }
|
70 |
|
71 | // Allow existing headers to be overridden
|
72 | // Allow new headers to be added
|
73 | if (endpoint.headers) {
|
74 | Object.keys(endpoint.headers).forEach(function (key) {
|
75 | options.headers[key] = endpoint.headers[key];
|
76 | });
|
77 | }
|
78 |
|
79 | if (this.credentials.signatureSecret && this.credentials.signatureMethod) {
|
80 | var splitPath = options.path.split(/\?(.+)/);
|
81 | var path = splitPath[0];
|
82 |
|
83 | var params = querystring.decode(splitPath[1]);
|
84 |
|
85 | // add timestamp if not already present
|
86 | if (!params.timestamp) {
|
87 | params.timestamp = new Date().getTime() / 1000 | 0; // floor to seconds
|
88 | params.timestamp = params.timestamp.toString();
|
89 | }
|
90 |
|
91 | // strip API Secret
|
92 | delete params.api_secret;
|
93 |
|
94 | var hash = this.credentials.generateSignature(params);
|
95 |
|
96 | var query = "";
|
97 |
|
98 | // rebuild query
|
99 | Object.keys(params).sort().forEach(function (key) {
|
100 | query += "&" + key + "=" + encodeURI(params[key]);
|
101 | });
|
102 |
|
103 | // replace the first & with ?
|
104 | query = query.replace(/&/i, "?");
|
105 |
|
106 | options.path = "" + path + query + "&sig=" + hash;
|
107 | }
|
108 |
|
109 | this.logger.info("Request:", options, "\nBody:", endpoint.body);
|
110 | var request;
|
111 |
|
112 | if (options.port === 443) {
|
113 | request = this.https.request(options);
|
114 | } else {
|
115 | request = this.http.request(options);
|
116 | }
|
117 |
|
118 | request.end(endpoint.body);
|
119 |
|
120 | // Keep an array of String or Buffers,
|
121 | // depending on content type (binary or JSON) of response
|
122 | var responseData = [];
|
123 |
|
124 | request.on("response", function (response) {
|
125 | var isBinary = response.headers["content-type"] === "application/octet-stream";
|
126 | if (!isBinary) {
|
127 | response.setEncoding("utf8");
|
128 | }
|
129 |
|
130 | response.on("data", function (chunk) {
|
131 | responseData.push(chunk);
|
132 | });
|
133 |
|
134 | response.on("end", function () {
|
135 | _this.logger.info("response ended:", response.statusCode);
|
136 | if (callback) {
|
137 | if (isBinary) {
|
138 | responseData = Buffer.concat(responseData);
|
139 | }
|
140 |
|
141 | _this.__parseResponse(response, responseData, endpoint.method, callback, skipJsonParsing, customResponseParser);
|
142 | }
|
143 | });
|
144 | response.on("close", function (e) {
|
145 | if (e) {
|
146 | _this.logger.error("problem with API request detailed stacktrace below ");
|
147 | _this.logger.error(e);
|
148 | callback(e);
|
149 | }
|
150 | });
|
151 | });
|
152 | request.on("error", function (e) {
|
153 | _this.logger.error("problem with API request detailed stacktrace below ");
|
154 | _this.logger.error(e);
|
155 | callback(e);
|
156 | });
|
157 | }
|
158 | }, {
|
159 | key: "__parseResponse",
|
160 | value: function __parseResponse(httpResponse, data, method, callback, skipJsonParsing, customResponseParser) {
|
161 | var isArrayOrBuffer = data instanceof Array || data instanceof Buffer;
|
162 | if (!isArrayOrBuffer) {
|
163 | throw new Error("data should be of type Array or Buffer");
|
164 | }
|
165 |
|
166 | var status = httpResponse.statusCode;
|
167 | var headers = httpResponse.headers;
|
168 |
|
169 | var response = null;
|
170 | var error = null;
|
171 |
|
172 | try {
|
173 | if (status >= 500) {
|
174 | error = {
|
175 | message: "Server Error",
|
176 | statusCode: status
|
177 | };
|
178 | } else if (httpResponse.headers["content-type"] === "application/octet-stream") {
|
179 | response = data;
|
180 | } else if (status === 429) {
|
181 | // 429 does not return a parsable body
|
182 | if (!headers["retry-after"]) {
|
183 | // retry based on allowed per second
|
184 | var retryAfterMillis = method === "POST" ? 1000 / 2 : 1000 / 5;
|
185 | headers["retry-after"] = retryAfterMillis;
|
186 | }
|
187 | error = {
|
188 | body: data.join("")
|
189 | };
|
190 | } else if (status === 204) {
|
191 | response = null;
|
192 | } else if (status >= 400 || status < 200) {
|
193 | error = {
|
194 | body: JSON.parse(data.join("")),
|
195 | headers: headers
|
196 | };
|
197 | } else if (method !== "DELETE") {
|
198 | if (!!skipJsonParsing) {
|
199 | response = data.join("");
|
200 | } else {
|
201 | response = JSON.parse(data.join(""));
|
202 | }
|
203 | } else {
|
204 | response = data;
|
205 | }
|
206 | } catch (parseError) {
|
207 | this.logger.error(parseError);
|
208 | this.logger.error("could not convert API response to JSON, above error is ignored and raw API response is returned to client");
|
209 | this.logger.error("Raw Error message from API ");
|
210 | this.logger.error("\"" + data + "\"");
|
211 |
|
212 | error = {
|
213 | status: status,
|
214 | message: "The API response could not be parsed.",
|
215 | body: data.join(""),
|
216 | parseError: parseError
|
217 | };
|
218 | }
|
219 |
|
220 | if (error) {
|
221 | error.statusCode = status;
|
222 | error.headers = headers;
|
223 | }
|
224 |
|
225 | if (typeof callback === "function") {
|
226 | if (typeof customResponseParser === "function") {
|
227 | // don't try to parse the response on errors
|
228 | if (response) {
|
229 | response = customResponseParser(response);
|
230 | }
|
231 | }
|
232 | callback(error, response);
|
233 | }
|
234 | }
|
235 | }, {
|
236 | key: "_addLimitedAccessMessageToErrors",
|
237 | value: function _addLimitedAccessMessageToErrors(callback, limitedAccessStatus) {
|
238 | return function (err, data) {
|
239 | if (err && err.status == limitedAccessStatus) {
|
240 | err._INFO_ = "This endpoint may need activating on your account. Please email support@nexmo.com for more information";
|
241 | }
|
242 |
|
243 | return callback(err, data);
|
244 | };
|
245 | }
|
246 | }, {
|
247 | key: "get",
|
248 | value: function get(path, params, callback) {
|
249 | var useJwt = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
250 | var useBasicAuth = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
|
251 |
|
252 | if (!callback) {
|
253 | if (typeof params == "function") {
|
254 | callback = params;
|
255 | params = {};
|
256 | }
|
257 | }
|
258 |
|
259 | params = params || {};
|
260 | if (!useJwt && !useBasicAuth) {
|
261 | params["api_key"] = this.credentials.apiKey;
|
262 | params["api_secret"] = this.credentials.apiSecret;
|
263 | }
|
264 |
|
265 | path = path + "?" + querystring.stringify(params);
|
266 |
|
267 | var headers = {
|
268 | "Content-Type": "application/json"
|
269 | };
|
270 | if (useJwt) {
|
271 | headers["Authorization"] = "Bearer " + this.credentials.generateJwt();
|
272 | }
|
273 | if (useBasicAuth) {
|
274 | headers["Authorization"] = "Basic " + Buffer.from(this.credentials.apiKey + ":" + this.credentials.apiSecret).toString("base64");
|
275 | }
|
276 |
|
277 | this.request({
|
278 | path: path,
|
279 | headers: headers
|
280 | }, "GET", callback);
|
281 | }
|
282 | }, {
|
283 | key: "delete",
|
284 | value: function _delete(path, callback, useJwt, useBasicAuth) {
|
285 | var params = {};
|
286 | if (!useJwt && !useBasicAuth) {
|
287 | params["api_key"] = this.credentials.apiKey;
|
288 | params["api_secret"] = this.credentials.apiSecret;
|
289 | }
|
290 |
|
291 | var headers = {};
|
292 |
|
293 | if (useBasicAuth) {
|
294 | headers["Authorization"] = "Basic " + Buffer.from(this.credentials.apiKey + ":" + this.credentials.apiSecret).toString("base64");
|
295 | }
|
296 | path = path + "?" + querystring.stringify(params);
|
297 |
|
298 | this.request({
|
299 | path: path,
|
300 | headers: headers
|
301 | }, "DELETE", callback);
|
302 | }
|
303 | }, {
|
304 | key: "postFile",
|
305 | value: function postFile(path, options, callback, useJwt) {
|
306 | var qs = {};
|
307 | if (!useJwt) {
|
308 | qs["api_key"] = this.credentials.apiKey;
|
309 | qs["api_secret"] = this.credentials.apiSecret;
|
310 | }
|
311 |
|
312 | if (Object.keys(qs).length) {
|
313 | var joinChar = "?";
|
314 | if (path.indexOf(joinChar) !== -1) {
|
315 | joinChar = "&";
|
316 | }
|
317 | path = path + joinChar + querystring.stringify(qs);
|
318 | }
|
319 |
|
320 | var file = options.file;
|
321 | delete options.file; // We don't send this as metadata
|
322 |
|
323 | var formData = {};
|
324 |
|
325 | if (file) {
|
326 | formData["filedata"] = {
|
327 | value: file,
|
328 | options: {
|
329 | filename: options.filename || null
|
330 | }
|
331 | };
|
332 | }
|
333 |
|
334 | if (options.info) {
|
335 | formData.info = JSON.stringify(options.info);
|
336 | }
|
337 |
|
338 | if (options.url) {
|
339 | formData.url = options.url;
|
340 | }
|
341 |
|
342 | this.requestLib.post({
|
343 | url: "https://" + this.host + path,
|
344 | formData: formData,
|
345 | headers: {
|
346 | Authorization: "Bearer " + this.credentials.generateJwt()
|
347 | }
|
348 | }, callback);
|
349 | }
|
350 | }, {
|
351 | key: "post",
|
352 | value: function post(path, params, callback, useJwt) {
|
353 | var qs = {};
|
354 | if (!useJwt) {
|
355 | qs["api_key"] = this.credentials.apiKey;
|
356 | qs["api_secret"] = this.credentials.apiSecret;
|
357 | }
|
358 |
|
359 | var joinChar = "?";
|
360 | if (path.indexOf(joinChar) !== -1) {
|
361 | joinChar = "&";
|
362 | }
|
363 |
|
364 | path = path + joinChar + querystring.stringify(qs);
|
365 |
|
366 | this.request({
|
367 | path: path,
|
368 | body: querystring.stringify(params)
|
369 | }, "POST", callback);
|
370 | }
|
371 | }, {
|
372 | key: "postJson",
|
373 | value: function postJson(path, params, callback, useJwt, useBasicAuth) {
|
374 | var qs = {};
|
375 | if (!useJwt && !useBasicAuth) {
|
376 | qs["api_key"] = this.credentials.apiKey;
|
377 | qs["api_secret"] = this.credentials.apiSecret;
|
378 | }
|
379 |
|
380 | var joinChar = "?";
|
381 | if (path.indexOf(joinChar) !== -1) {
|
382 | joinChar = "&";
|
383 | }
|
384 |
|
385 | path = path + joinChar + querystring.stringify(qs);
|
386 |
|
387 | var headers = {
|
388 | "Content-Type": "application/json"
|
389 | };
|
390 | if (useBasicAuth) {
|
391 | headers["Authorization"] = "Basic " + Buffer.from(this.credentials.apiKey + ":" + this.credentials.apiSecret).toString("base64");
|
392 | }
|
393 |
|
394 | this.request({
|
395 | path: path,
|
396 | body: JSON.stringify(params),
|
397 | headers: headers
|
398 | }, "POST", callback);
|
399 | }
|
400 | }, {
|
401 | key: "postUseQueryString",
|
402 | value: function postUseQueryString(path, params, callback, useJwt) {
|
403 | params = params || {};
|
404 | if (!useJwt) {
|
405 | params["api_key"] = this.credentials.apiKey;
|
406 | params["api_secret"] = this.credentials.apiSecret;
|
407 | }
|
408 |
|
409 | path = path + "?" + querystring.stringify(params);
|
410 |
|
411 | this.request({
|
412 | path: path
|
413 | }, "POST", callback);
|
414 | }
|
415 | }]);
|
416 |
|
417 | return HttpClient;
|
418 | }();
|
419 |
|
420 | exports.default = HttpClient;
|
421 | module.exports = exports["default"];
|
422 | //# 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","customResponseParser","path","Object","assign","undefined","keys","forEach","key","signatureSecret","signatureMethod","splitPath","split","params","decode","timestamp","Date","getTime","toString","api_secret","hash","generateSignature","query","sort","encodeURI","replace","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_","useJwt","useBasicAuth","apiKey","apiSecret","stringify","generateJwt","from","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(\n    endpoint,\n    method,\n    callback,\n    skipJsonParsing = false,\n    customResponseParser\n  ) {\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    if (this.credentials.signatureSecret && this.credentials.signatureMethod) {\n      const splitPath = options.path.split(/\\?(.+)/);\n      const path = splitPath[0];\n\n      var params = querystring.decode(splitPath[1]);\n\n      // add timestamp if not already present\n      if (!params.timestamp) {\n        params.timestamp = (new Date().getTime() / 1000) | 0; // floor to seconds\n        params.timestamp = params.timestamp.toString();\n      }\n\n      // strip API Secret\n      delete params.api_secret;\n\n      const hash = this.credentials.generateSignature(params);\n\n      var query = \"\";\n\n      // rebuild query\n      Object.keys(params)\n        .sort()\n        .forEach(key => {\n          query += \"&\" + key + \"=\" + encodeURI(params[key]);\n        });\n\n      // replace the first & with ?\n      query = query.replace(/&/i, \"?\");\n\n      options.path = `${path}${query}&sig=${hash}`;\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            customResponseParser\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(\n    httpResponse,\n    data,\n    method,\n    callback,\n    skipJsonParsing,\n    customResponseParser\n  ) {\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 = {\n          message: \"Server Error\",\n          statusCode: status\n        };\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 = {\n          body: data.join(\"\")\n        };\n      } else if (status === 204) {\n        response = null;\n      } else if (status >= 400 || status < 200) {\n        error = {\n          body: JSON.parse(data.join(\"\")),\n          headers\n        };\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      if (typeof customResponseParser === \"function\") {\n        // don't try to parse the response on errors\n        if (response) {\n          response = customResponseParser(response);\n        }\n      }\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 = {\n      \"Content-Type\": \"application/json\"\n    };\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(\n      {\n        path: path,\n        headers\n      },\n      \"GET\",\n      callback\n    );\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(\n      {\n        path: path,\n        headers\n      },\n      \"DELETE\",\n      callback\n    );\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      {\n        path: path,\n        body: querystring.stringify(params)\n      },\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 = {\n      \"Content-Type\": \"application/json\"\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(\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(\n      {\n        path: path\n      },\n      \"POST\",\n      callback\n    );\n  }\n}\n\nexport default HttpClient;\n"]} |
\ | No newline at end of file |