Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

chain-xhr

Package Overview
Dependencies
Maintainers
1
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

chain-xhr - npm Package Compare versions

Comparing version 0.1.2 to 0.2.0

118

chain-xhr.js

@@ -735,13 +735,51 @@ function createCommonjsModule(fn, module) {

function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
try {
var info = gen[key](arg);
var value = info.value;
} catch (error) {
reject(error);
return;
}
if (info.done) {
resolve(value);
} else {
Promise.resolve(value).then(_next, _throw);
}
}
function _asyncToGenerator(fn) {
return function () {
var self = this,
args = arguments;
return new Promise(function (resolve, reject) {
var gen = fn.apply(self, args);
function _next(value) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
}
function _throw(err) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
}
_next(undefined);
});
};
}
var asyncToGenerator = _asyncToGenerator;
var _typeof_1 = createCommonjsModule(function (module) {
function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); }
function _typeof(obj) {
"@babel/helpers - typeof";
function _typeof(obj) {
if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") {
if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
module.exports = _typeof = function _typeof(obj) {
return _typeof2(obj);
return typeof obj;
};
} else {
module.exports = _typeof = function _typeof(obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj);
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
};

@@ -883,3 +921,3 @@ }

if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen');
if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen');
this._request.method = methodNormalized;

@@ -1043,41 +1081,51 @@ return this;

key: "send",
value: function send() {
var _this = this;
value: function () {
var _send = asyncToGenerator(
/*#__PURE__*/
regenerator.mark(function _callee() {
var _this = this;
return regenerator.async(function send$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
return _context.abrupt("return", new Promise(function (resolve, reject) {
_this._request.queryParams.map(function (queryParam) {
return _this._request.url.searchParams.append(queryParam.key, queryParam.value);
});
return regenerator.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
return _context.abrupt("return", new Promise(function (resolve, reject) {
_this._request.queryParams.map(function (queryParam) {
return _this._request.url.searchParams.append(queryParam.key, queryParam.value);
});
_this._XHR = new XMLHttpRequest();
_this._XHR = new XMLHttpRequest();
_this._XHR.addEventListener('readystatechange', function () {
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject();
});
_this._XHR.addEventListener('readystatechange', function () {
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject();
});
_this._XHR.addEventListener('error', function (err) {
return reject(err);
});
_this._XHR.addEventListener('error', function (err) {
return reject(err);
});
_this._XHR.open(_this._request.method, _this._request.url.href, true);
_this._XHR.open(_this._request.method, _this._request.url.href, true);
_this._XHR.responseType = _this._request.responseType;
_this._XHR.withCredentials = _this._request.withCredentials;
_this._XHR.responseType = _this._request.responseType;
_this._XHR.withCredentials = _this._request.withCredentials;
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType);
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType);
_this._XHR.send(_this._request.data);
}));
_this._XHR.send(_this._request.data);
}));
case 1:
case "end":
return _context.stop();
case 1:
case "end":
return _context.stop();
}
}
}
});
}
}, _callee);
}));
function send() {
return _send.apply(this, arguments);
}
return send;
}()
}]);

@@ -1084,0 +1132,0 @@

@@ -0,1 +1,15 @@

0.2.0 / 2019-02-02
==================
* [FEATURE] Defined the Methods interface more clearly.
* [TEST] Changed the test setup to use require instead of import.
* [TEST] Added @ava/babel due to problems using import in tests.
* [MISC] Updated dependencies to their latest versions.
* [MISC] Updated license year to reflect year change.
* [MISC] Removed unnecessary spacing.
0.1.3 / 2019-12-19
==================
* [MISC] Updated dependencies to their latest versions.
* [MISC] Added more badges to README.
0.1.2 / 2019-11-10

@@ -13,2 +27,2 @@ ==================

==================
* Initial release
* Initial release
export {};

@@ -7,2 +7,4 @@ 'use strict';

var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));

@@ -97,3 +99,3 @@

if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen');
if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen');
this._request.method = methodNormalized;

@@ -257,44 +259,54 @@ return this;

key: "send",
value: function send() {
var _this = this;
value: function () {
var _send = (0, _asyncToGenerator2["default"])(
/*#__PURE__*/
_regenerator["default"].mark(function _callee() {
var _this = this;
return _regenerator["default"].async(function send$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
return _context.abrupt("return", new Promise(function (resolve, reject) {
_this._request.queryParams.map(function (queryParam) {
return _this._request.url.searchParams.append(queryParam.key, queryParam.value);
});
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
return _context.abrupt("return", new Promise(function (resolve, reject) {
_this._request.queryParams.map(function (queryParam) {
return _this._request.url.searchParams.append(queryParam.key, queryParam.value);
});
_this._XHR = new XMLHttpRequest();
_this._XHR = new XMLHttpRequest();
_this._XHR.addEventListener('readystatechange', function () {
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject();
});
_this._XHR.addEventListener('readystatechange', function () {
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject();
});
_this._XHR.addEventListener('error', function (err) {
return reject(err);
});
_this._XHR.addEventListener('error', function (err) {
return reject(err);
});
_this._XHR.open(_this._request.method, _this._request.url.href, true);
_this._XHR.open(_this._request.method, _this._request.url.href, true);
_this._XHR.responseType = _this._request.responseType;
_this._XHR.withCredentials = _this._request.withCredentials;
_this._XHR.responseType = _this._request.responseType;
_this._XHR.withCredentials = _this._request.withCredentials;
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType);
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType);
_this._XHR.send(_this._request.data);
}));
_this._XHR.send(_this._request.data);
}));
case 1:
case "end":
return _context.stop();
case 1:
case "end":
return _context.stop();
}
}
}
});
}
}, _callee);
}));
function send() {
return _send.apply(this, arguments);
}
return send;
}()
}]);
return ChainXHR;
}(), _temp);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.ts"],"names":["module","exports","GET","POST","PUT","DELETE","method","METHODS","withCredentials","contentType","queryParams","responseType","url","_request","URL","methodNormalized","toUpperCase","Error","key","value","valueNormalized","toString","push","data","FormData","JSON","stringify","_XHR","abort","Promise","resolve","reject","map","queryParam","searchParams","append","XMLHttpRequest","addEventListener","readyState","status","response","err","open","href","setRequestHeader","send"],"mappings":"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","sourcesContent":["'use strict'\r\n\r\nimport Methods from './interfaces/Methods';\r\nimport Request from './interfaces/Request';\r\n\r\n/**\r\n * chain-xhr provides an easy to use promise bbased chainable API that makes it simple to create any kind of XHR request.\r\n */\r\nmodule.exports = class ChainXHR {\r\n\r\n  /**\r\n   * A constant that can be used to select the requested http request method from.\r\n   * \r\n   * Even if a request method is provided by hand, it will be double checked against the ones defined here to make sure that it\r\n   * is a valid request method.\r\n   * \r\n   * @property {Object}\r\n   */\r\n  METHODS: Methods = {\r\n    GET: 'GET',\r\n    POST: 'POST',\r\n    PUT: 'PUT',\r\n    DELETE: 'DELETE'\r\n  };\r\n\r\n  /**\r\n   * A reference to the request object that will be used to build and send the final request.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Request}\r\n   */\r\n  private _request: Request = {\r\n    method: this.METHODS.GET,\r\n    withCredentials: false,\r\n    contentType: 'application/json',\r\n    queryParams: [],\r\n    responseType: 'text'\r\n  };\r\n\r\n  /**\r\n   * A reference to the actual XMLHttpRequest.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {XMLHttpRequest}\r\n   */\r\n  private _XHR!: XMLHttpRequest;\r\n\r\n  /**\r\n   * Set the URL that this request should be sent to.\r\n   * \r\n   * This request can fail if an invalid url is provided so it is recommended to wrap it in a try..catch if you believe there is any\r\n   * chance of that happening.\r\n   * \r\n   * @param {string} url The url to send this request to.\r\n   * \r\n   * @returns {ChainXHR} Returns this for chaining.\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .url('https://example.com');\r\n   */\r\n  url(url: string): ChainXHR {\r\n\r\n    this._request.url = new URL(url);\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets the http request method to be used by this XHR request.\r\n   * \r\n   * By default this property is set to 'GET'.\r\n   * \r\n   * You can choose to type in a string directly such as 'GET' or 'get' or you can use the REQUEST constant of ChainXHR to set this.\r\n   * \r\n   * @param {string} method The http request method to use for this XHR request.\r\n   * \r\n   * @returns {ChainXHR} Returns this for chaining.\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * // Using a string directly:\r\n   * request\r\n   *  .url('https://example.com')\r\n   *  .method('GET');\r\n   * \r\n   * // Using the constant:\r\n   * request\r\n   *  .url('https://example.com');\r\n   *  .method(request.METHOD.GET);\r\n   */\r\n  method(method: string): ChainXHR {\r\n\r\n    const methodNormalized = method.toUpperCase();\r\n\r\n    if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen');\r\n\r\n    this._request.method = methodNormalized;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets this request to be made with credentials such as cookies, authorization headers, or TLS certificates.\r\n   * \r\n   * By default this property is set to false.\r\n   * \r\n   * This has no effect on same-site requests.\r\n   * \r\n   * @returns {ChainXHR} Returns this for chaining.\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .withCredentials();\r\n   */\r\n  withCredentials(): ChainXHR {\r\n\r\n    this._request.withCredentials = true;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets the content type header which indicates what type of content is being send to the endpoint.\r\n   * \r\n   * By default this is set to 'application/json'.\r\n   * \r\n   * @param {string} contentType The type of content that is being sent to the server.\r\n   * \r\n   * @returns {ChainXHR}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .contentType('x-www-formdata');\r\n   */\r\n  contentType(contentType: string): ChainXHR {\r\n\r\n    this._request.contentType = contentType;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Adds a query parameter to send with the request.\r\n   * \r\n   * This should be chained multiple times to add multiple query parameters.\r\n   * \r\n   * @param {string} key The key of the query parameter to add.\r\n   * @param {string|number|boolean} value The value of the key added.\r\n   * \r\n   * @returns {ChainXHR}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .queryParam('hello', 'world')\r\n   *  .queryParam('count', 5);\r\n   */\r\n  queryParam(key: string, value: (string | number | boolean)): ChainXHR {\r\n\r\n    const valueNormalized: string = value.toString();\r\n\r\n    this._request.queryParams.push({ key: key, value: valueNormalized });\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets the data to send through with the request.\r\n   * \r\n   * @param {*} data The data to send through with the request.\r\n   * \r\n   * @returns {ChainXHR}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * // Sending an object.\r\n   * const obj = { hello: 'world', year: 2019 };\r\n   * \r\n   * request\r\n   *  .data(obj);\r\n   * \r\n   * // Sending key value pairs individually.\r\n   * request\r\n   *  .data('hello', 'world')\r\n   *  .data('year', 2019);\r\n   */\r\n  data(data: (Object | string)): ChainXHR {\r\n\r\n    if (typeof data === 'object' && ((data instanceof FormData) === false)) data = JSON.stringify(data);\r\n\r\n    this._request.data = data;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Specifies that the data returned should be JSON parsed.\r\n   * \r\n   * @returns {ChainXHR}\r\n   */\r\n  json(): ChainXHR {\r\n\r\n    this._request.responseType = 'json';\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Aborts the request if it already has been sent.\r\n   * \r\n   * When a request is aborted, its readystate is changed to 0 and the status code is set to 0 also.\r\n   * \r\n   * @returns {ChainXHR}\r\n   */\r\n  abort(): ChainXHR {\r\n\r\n    this._XHR.abort();\r\n\r\n    return this;\r\n    \r\n  }\r\n\r\n  /**\r\n   * Indicates that the XHR request is finished being built and is ready to be sent.\r\n   * \r\n   * This should always be the final method used in all requests.\r\n   * \r\n   * @async\r\n   * \r\n   * @returns {Promise<any>}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .url('https://example.com')\r\n   *  .method('GET')\r\n   *  .send();\r\n   */\r\n  async send(): Promise<any> {\r\n\r\n    return new Promise((resolve, reject) => {\r\n\r\n      this._request.queryParams.map(queryParam => this._request.url!.searchParams.append(queryParam.key, queryParam.value));\r\n\r\n      this._XHR = new XMLHttpRequest();\r\n\r\n      this._XHR.addEventListener('readystatechange', () => {\r\n\r\n        if (this._XHR.readyState === 4 && this._XHR.status >= 200) resolve(this._XHR.response);\r\n\r\n        else if (this._XHR.status >= 400 && this._XHR.status <= 600) reject();\r\n\r\n      });\r\n\r\n      this._XHR.addEventListener('error', (err: Event) => reject(err));\r\n\r\n      this._XHR.open(this._request.method, this._request.url!.href, true);\r\n\r\n      this._XHR.responseType = <XMLHttpRequestResponseType>this._request.responseType;\r\n\r\n      this._XHR.withCredentials = this._request.withCredentials;\r\n\r\n      this._XHR.setRequestHeader('Content-Type', this._request.contentType);\r\n\r\n      this._XHR.send(this._request.data!);\r\n\r\n    });\r\n\r\n  }\r\n\r\n};"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.ts"],"names":["module","exports","GET","POST","PUT","DELETE","method","METHODS","withCredentials","contentType","queryParams","responseType","url","_request","URL","methodNormalized","toUpperCase","hasOwnProperty","Error","key","value","valueNormalized","toString","push","data","FormData","JSON","stringify","_XHR","abort","Promise","resolve","reject","map","queryParam","searchParams","append","XMLHttpRequest","addEventListener","readyState","status","response","err","open","href","setRequestHeader","send"],"mappings":"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","sourcesContent":["'use strict'\n\nimport Methods from './interfaces/Methods';\nimport Request from './interfaces/Request';\n\n/**\n * chain-xhr provides an easy to use promise bbased chainable API that makes it simple to create any kind of XHR request.\n */\nmodule.exports = class ChainXHR {\n  /** * A constant that can be used to select the requested http request method from.  * \n   * Even if a request method is provided by hand, it will be double checked against the ones defined here to make sure that it\n   * is a valid request method.\n   * \n   * @property {Object}\n   */\n  METHODS: Methods = {\n    GET: 'GET',\n    POST: 'POST',\n    PUT: 'PUT',\n    DELETE: 'DELETE'\n  };\n\n  /**\n   * A reference to the request object that will be used to build and send the final request.\n   * \n   * @private\n   * \n   * @property {Request}\n   */\n  private _request: Request = {\n    method: this.METHODS.GET,\n    withCredentials: false,\n    contentType: 'application/json',\n    queryParams: [],\n    responseType: 'text'\n  };\n\n  /**\n   * A reference to the actual XMLHttpRequest.\n   * \n   * @private\n   * \n   * @property {XMLHttpRequest}\n   */\n  private _XHR!: XMLHttpRequest;\n\n  /**\n   * Set the URL that this request should be sent to.\n   * \n   * This request can fail if an invalid url is provided so it is recommended to wrap it in a try..catch if you believe there is any\n   * chance of that happening.\n   * \n   * @param {string} url The url to send this request to.\n   * \n   * @returns {ChainXHR} Returns this for chaining.\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .url('https://example.com');\n   */\n  url(url: string): ChainXHR {\n    this._request.url = new URL(url);\n\n    return this;\n  }\n\n  /**\n   * Sets the http request method to be used by this XHR request.\n   * \n   * By default this property is set to 'GET'.\n   * \n   * You can choose to type in a string directly such as 'GET' or 'get' or you can use the REQUEST constant of ChainXHR to set this.\n   * \n   * @param {string} method The http request method to use for this XHR request.\n   * \n   * @returns {ChainXHR} Returns this for chaining.\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * // Using a string directly:\n   * request\n   *  .url('https://example.com')\n   *  .method('GET');\n   * \n   * // Using the constant:\n   * request\n   *  .url('https://example.com');\n   *  .method(request.METHOD.GET);\n   */\n  method(method: string): ChainXHR {\n    const methodNormalized = method.toUpperCase();\n\n    if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen');\n\n    this._request.method = methodNormalized;\n\n    return this;\n  }\n\n  /**\n   * Sets this request to be made with credentials such as cookies, authorization headers, or TLS certificates.\n   * \n   * By default this property is set to false.\n   * \n   * This has no effect on same-site requests.\n   * \n   * @returns {ChainXHR} Returns this for chaining.\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .withCredentials();\n   */\n  withCredentials(): ChainXHR {\n    this._request.withCredentials = true;\n\n    return this;\n  }\n\n  /**\n   * Sets the content type header which indicates what type of content is being send to the endpoint.\n   * \n   * By default this is set to 'application/json'.\n   * \n   * @param {string} contentType The type of content that is being sent to the server.\n   * \n   * @returns {ChainXHR}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .contentType('x-www-formdata');\n   */\n  contentType(contentType: string): ChainXHR {\n    this._request.contentType = contentType;\n\n    return this;\n  }\n\n  /**\n   * Adds a query parameter to send with the request.\n   * \n   * This should be chained multiple times to add multiple query parameters.\n   * \n   * @param {string} key The key of the query parameter to add.\n   * @param {string|number|boolean} value The value of the key added.\n   * \n   * @returns {ChainXHR}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .queryParam('hello', 'world')\n   *  .queryParam('count', 5);\n   */\n  queryParam(key: string, value: (string | number | boolean)): ChainXHR {\n    const valueNormalized: string = value.toString();\n\n    this._request.queryParams.push({ key: key, value: valueNormalized });\n\n    return this;\n  }\n\n  /**\n   * Sets the data to send through with the request.\n   * \n   * @param {*} data The data to send through with the request.\n   * \n   * @returns {ChainXHR}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * // Sending an object.\n   * const obj = { hello: 'world', year: 2019 };\n   * \n   * request\n   *  .data(obj);\n   * \n   * // Sending key value pairs individually.\n   * request\n   *  .data('hello', 'world')\n   *  .data('year', 2019);\n   */\n  data(data: (Object | string)): ChainXHR {\n    if (typeof data === 'object' && ((data instanceof FormData) === false)) data = JSON.stringify(data);\n\n    this._request.data = data;\n\n    return this;\n  }\n\n  /**\n   * Specifies that the data returned should be JSON parsed.\n   * \n   * @returns {ChainXHR}\n   */\n  json(): ChainXHR {\n    this._request.responseType = 'json';\n\n    return this;\n  }\n\n  /**\n   * Aborts the request if it already has been sent.\n   * \n   * When a request is aborted, its readystate is changed to 0 and the status code is set to 0 also.\n   * \n   * @returns {ChainXHR}\n   */\n  abort(): ChainXHR {\n    this._XHR.abort();\n\n    return this;\n  }\n\n  /**\n   * Indicates that the XHR request is finished being built and is ready to be sent.\n   * \n   * This should always be the final method used in all requests.\n   * \n   * @async\n   * \n   * @returns {Promise<any>}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .url('https://example.com')\n   *  .method('GET')\n   *  .send();\n   */\n  async send(): Promise<any> {\n    return new Promise((resolve, reject) => {\n      this._request.queryParams.map(queryParam => this._request.url!.searchParams.append(queryParam.key, queryParam.value));\n\n      this._XHR = new XMLHttpRequest();\n\n      this._XHR.addEventListener('readystatechange', () => {\n        if (this._XHR.readyState === 4 && this._XHR.status >= 200) resolve(this._XHR.response);\n        else if (this._XHR.status >= 400 && this._XHR.status <= 600) reject();\n      });\n\n      this._XHR.addEventListener('error', (err: Event) => reject(err));\n\n      this._XHR.open(this._request.method, this._request.url!.href, true);\n\n      this._XHR.responseType = <XMLHttpRequestResponseType>this._request.responseType;\n\n      this._XHR.withCredentials = this._request.withCredentials;\n\n      this._XHR.setRequestHeader('Content-Type', this._request.contentType);\n\n      this._XHR.send(this._request.data!);\n    });\n  }\n};\n"]}

@@ -5,3 +5,6 @@ /**

export default interface Methods {
[method: string]: string;
GET: string;
POST: string;
PUT: string;
DELETE: string;
}

@@ -7,2 +7,2 @@ 'use strict';

;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL01ldGhvZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQU9DIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnXHJcblxyXG4vKipcclxuICogRGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIHRoZSBNRVRIT0RTIGNvbnN0YW50IE9iamVjdC5cclxuICovXHJcbmV4cG9ydCBkZWZhdWx0IGludGVyZmFjZSBNZXRob2RzIHtcclxuXHJcbiAgW21ldGhvZDogc3RyaW5nXTogc3RyaW5nO1xyXG5cclxufTsiXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL01ldGhvZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQVFDIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnXG5cbi8qKlxuICogRGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIHRoZSBNRVRIT0RTIGNvbnN0YW50IE9iamVjdC5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgaW50ZXJmYWNlIE1ldGhvZHMge1xuICBHRVQ6IHN0cmluZztcbiAgUE9TVDogc3RyaW5nO1xuICBQVVQ6IHN0cmluZztcbiAgREVMRVRFOiBzdHJpbmc7XG59O1xuIl19

@@ -0,0 +0,0 @@ /**

@@ -7,2 +7,2 @@ 'use strict';

;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL1JlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQXdDQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0J1xyXG5cclxuLyoqXHJcbiAqIERlZmluZXMgdGhlIHN0cnVjdHVyZSBvZiBhIFhIUiByZXF1ZXN0LlxyXG4gKi9cclxuZXhwb3J0IGRlZmF1bHQgaW50ZXJmYWNlIFJlcXVlc3Qge1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgVVJMIHRoYXQgdGhlIHJlcXVlc3Qgc2hvdWxkIGJlIHNlbnQgdG8uXHJcbiAgICovXHJcbiAgdXJsPzogVVJMO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgaHR0cCByZXF1ZXN0IG1ldGhvZCB0aGF0IHNob3VsZCBiZSB1c2VkIGZvciB0aGlzIHJlcXVlc3QuXHJcbiAgICovXHJcbiAgbWV0aG9kOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRoaXMgcmVxdWVzdCB3aWxsIGJlIG1hZGUgd2l0aCBjcmVkZW50aWFscyBvciBub3QuXHJcbiAgICovXHJcbiAgd2l0aENyZWRlbnRpYWxzOiBib29sZWFuO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgY29udGVudCB0eXBlIG9mIHRoZSBjb250ZW50IGJlaW5nIHNlbnQgdG8gdGhlIGVuZHBvaW50LlxyXG4gICAqL1xyXG4gIGNvbnRlbnRUeXBlOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBxdWVyeSBwYXJhbWV0ZXJzIHRvIGFkZCB0byB0aGUgZW5kIG9mIHRoZSByZXF1ZXN0IHVybC5cclxuICAgKi9cclxuICBxdWVyeVBhcmFtczogQXJyYXk8YW55PjtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHR5cGUgb2YgZGF0YSB0aGF0IHRoZSByZXNwb25zZSBzaG91bGQgYmUuXHJcbiAgICovXHJcbiAgcmVzcG9uc2VUeXBlOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBkYXRhIHRvIHNlbmQgd2l0aCB0aGUgcmVxdWVzdC5cclxuICAgKi9cclxuICBkYXRhPzogYW55O1xyXG5cclxufTsiXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL1JlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQXNDQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0J1xuXG4vKipcbiAqIERlZmluZXMgdGhlIHN0cnVjdHVyZSBvZiBhIFhIUiByZXF1ZXN0LlxuICovXG5leHBvcnQgZGVmYXVsdCBpbnRlcmZhY2UgUmVxdWVzdCB7XG4gIC8qKlxuICAgKiBUaGUgVVJMIHRoYXQgdGhlIHJlcXVlc3Qgc2hvdWxkIGJlIHNlbnQgdG8uXG4gICAqL1xuICB1cmw/OiBVUkw7XG5cbiAgLyoqXG4gICAqIFRoZSBodHRwIHJlcXVlc3QgbWV0aG9kIHRoYXQgc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgcmVxdWVzdC5cbiAgICovXG4gIG1ldGhvZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGlzIHJlcXVlc3Qgd2lsbCBiZSBtYWRlIHdpdGggY3JlZGVudGlhbHMgb3Igbm90LlxuICAgKi9cbiAgd2l0aENyZWRlbnRpYWxzOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUaGUgY29udGVudCB0eXBlIG9mIHRoZSBjb250ZW50IGJlaW5nIHNlbnQgdG8gdGhlIGVuZHBvaW50LlxuICAgKi9cbiAgY29udGVudFR5cGU6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHF1ZXJ5IHBhcmFtZXRlcnMgdG8gYWRkIHRvIHRoZSBlbmQgb2YgdGhlIHJlcXVlc3QgdXJsLlxuICAgKi9cbiAgcXVlcnlQYXJhbXM6IEFycmF5PGFueT47XG5cbiAgLyoqXG4gICAqIFRoZSB0eXBlIG9mIGRhdGEgdGhhdCB0aGUgcmVzcG9uc2Ugc2hvdWxkIGJlLlxuICAgKi9cbiAgcmVzcG9uc2VUeXBlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBkYXRhIHRvIHNlbmQgd2l0aCB0aGUgcmVxdWVzdC5cbiAgICovXG4gIGRhdGE/OiBhbnk7XG59O1xuIl19
{
"name": "chain-xhr",
"version": "0.1.2",
"description": "As stated in the MDN docs, a XMLHttpRequest is the safest and most reliable way to make HTTP requests. chain-xhr aims to make making XHR requests as simple as possible through a chainable API",
"version": "0.2.0",
"description": "A XMLHttpRequest is the safest and most reliable way to make HTTP requests and chain-xhr aims to make making XHR requests as simple as possible through a chainable API",
"main": "chain-xhr.js",

@@ -20,3 +20,4 @@ "scripts": {

"./test/_setup-browser-env.js"
]
],
"babel": true
},

@@ -41,21 +42,22 @@ "repository": {

"devDependencies": {
"@babel/cli": "^7.7.0",
"@babel/core": "^7.7.2",
"@babel/plugin-proposal-class-properties": "^7.7.0",
"@babel/plugin-proposal-numeric-separator": "^7.2.0",
"@babel/plugin-proposal-object-rest-spread": "^7.6.2",
"@babel/plugin-transform-runtime": "^7.6.2",
"@babel/preset-env": "^7.7.1",
"@babel/preset-typescript": "^7.7.2",
"ava": "^2.4.0",
"@ava/babel": "^1.0.0",
"@babel/cli": "^7.8.4",
"@babel/core": "^7.8.4",
"@babel/plugin-proposal-class-properties": "^7.8.3",
"@babel/plugin-proposal-numeric-separator": "^7.8.3",
"@babel/plugin-proposal-object-rest-spread": "^7.8.3",
"@babel/plugin-transform-runtime": "^7.8.3",
"@babel/preset-env": "^7.8.4",
"@babel/preset-typescript": "^7.8.3",
"ava": "^3.2.0",
"browser-env": "^3.3.0",
"rollup": "^1.26.4",
"rollup": "^1.31.0",
"rollup-plugin-babel": "^4.3.3",
"rollup-plugin-commonjs": "^10.1.0",
"rollup-plugin-node-resolve": "^5.2.0",
"typescript": "^3.7.2"
"typescript": "^3.7.5"
},
"dependencies": {
"@babel/runtime": "^7.7.2"
"@babel/runtime": "^7.8.4"
}
}

@@ -13,8 +13,9 @@ <div align="center">

[![NPM version](https://img.shields.io/npm/v/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr)
[![Known Vulnerabilities](https://snyk.io/test/github/robertcorponoi/chain-xhr/badge.svg)](https://snyk.io/test/github/robertcorponoi/chain-xhr)
[![NPM downloads](https://img.shields.io/npm/dm/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr)
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/issues/robertcorponoi/chain-xhr.svg" alt="issues" height="18"></a>
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/license/robertcorponoi/chain-xhr.svg" alt="license" height="18"></a>
[![Gitter](https://badges.gitter.im/gitterHQ/gitter.svg)](https://gitter.im/robertcorponoi)
[![NPM version](https://img.shields.io/npm/v/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr)
[![Known Vulnerabilities](https://snyk.io/test/github/robertcorponoi/chain-xhr/badge.svg)](https://snyk.io/test/github/robertcorponoi/chain-xhr)
![npm](https://img.shields.io/npm/dt/chain-xhr)
[![NPM downloads](https://img.shields.io/npm/dm/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr)
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/issues/robertcorponoi/chain-xhr.svg" alt="issues" height="18"></a>
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/license/robertcorponoi/chain-xhr.svg" alt="license" height="18"></a>
[![Gitter](https://badges.gitter.im/gitterHQ/gitter.svg)](https://gitter.im/robertcorponoi)

@@ -21,0 +22,0 @@ </div>

@@ -0,0 +0,0 @@ 'use strict'

@@ -10,6 +10,3 @@ 'use strict'

module.exports = class ChainXHR {
/**
* A constant that can be used to select the requested http request method from.
*
/** * A constant that can be used to select the requested http request method from. *
* Even if a request method is provided by hand, it will be double checked against the ones defined here to make sure that it

@@ -69,7 +66,5 @@ * is a valid request method.

url(url: string): ChainXHR {
this._request.url = new URL(url);
return this;
}

@@ -103,6 +98,5 @@

method(method: string): ChainXHR {
const methodNormalized = method.toUpperCase();
if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen');
if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen');

@@ -112,3 +106,2 @@ this._request.method = methodNormalized;

return this;
}

@@ -133,7 +126,5 @@

withCredentials(): ChainXHR {
this._request.withCredentials = true;
return this;
}

@@ -158,7 +149,5 @@

contentType(contentType: string): ChainXHR {
this._request.contentType = contentType;
return this;
}

@@ -185,3 +174,2 @@

queryParam(key: string, value: (string | number | boolean)): ChainXHR {
const valueNormalized: string = value.toString();

@@ -192,3 +180,2 @@

return this;
}

@@ -219,3 +206,2 @@

data(data: (Object | string)): ChainXHR {
if (typeof data === 'object' && ((data instanceof FormData) === false)) data = JSON.stringify(data);

@@ -226,3 +212,2 @@

return this;
}

@@ -236,7 +221,5 @@

json(): ChainXHR {
this._request.responseType = 'json';
return this;
}

@@ -252,7 +235,5 @@

abort(): ChainXHR {
this._XHR.abort();
return this;
}

@@ -279,5 +260,3 @@

async send(): Promise<any> {
return new Promise((resolve, reject) => {
this._request.queryParams.map(queryParam => this._request.url!.searchParams.append(queryParam.key, queryParam.value));

@@ -288,7 +267,4 @@

this._XHR.addEventListener('readystatechange', () => {
if (this._XHR.readyState === 4 && this._XHR.status >= 200) resolve(this._XHR.response);
else if (this._XHR.status >= 400 && this._XHR.status <= 600) reject();
});

@@ -307,7 +283,4 @@

this._XHR.send(this._request.data!);
});
}
};
};

@@ -7,5 +7,6 @@ 'use strict'

export default interface Methods {
[method: string]: string;
};
GET: string;
POST: string;
PUT: string;
DELETE: string;
};

@@ -7,3 +7,2 @@ 'use strict'

export default interface Request {
/**

@@ -43,3 +42,2 @@ * The URL that the request should be sent to.

data?: any;
};
};
'use strict';
import browserEnv from 'browser-env';
const browserEnv = require('browser-env');
browserEnv();
browserEnv();

@@ -0,0 +0,0 @@ 'use strict'

@@ -0,0 +0,0 @@ {

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc