Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pwnall/node-xhr2
XMLHttpRequest emulator for node.js
https://github.com/pwnall/node-xhr2
Last synced: 1 day ago
JSON representation
XMLHttpRequest emulator for node.js
- Host: GitHub
- URL: https://github.com/pwnall/node-xhr2
- Owner: pwnall
- License: mit
- Created: 2013-01-28T10:38:48.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2022-09-01T16:03:36.000Z (over 2 years ago)
- Last Synced: 2024-10-30T05:58:01.299Z (2 months ago)
- Language: CoffeeScript
- Size: 79.1 KB
- Stars: 104
- Watchers: 5
- Forks: 41
- Open Issues: 26
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-ponyfills - xhr2 - [`XMLHttpRequest`](https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest) (Browser Features)
README
# XMLHttpRequest Emulation for node.js
This is an [npm](https://npmjs.org/) package that implements the
[W3C XMLHttpRequest](http://www.w3.org/TR/XMLHttpRequest/) specification on top
of the [node.js](http://nodejs.org/) APIs.## Supported Platforms
This library is tested against the following platforms.
* [node.js](http://nodejs.org/) 10
* [node.js](http://nodejs.org/) 12Keep in mind that the versions above are not hard requirements.
## Installation and Usage
The preferred installation method is to add the library to the `dependencies`
section in your `package.json`.```json
{
"dependencies": {
"xhr2": "*"
}
}
```Alternatively, `npm` can be used to install the library directly.
```bash
npm install xhr2
```Once the library is installed, `require`-ing it returns the `XMLHttpRequest`
constructor.```javascript
var XMLHttpRequest = require('xhr2');
```The other objects that are usually defined in an XHR environment are hanging
off of `XMLHttpRequest`.```javascript
var XMLHttpRequestUpload = XMLHttpRequest.XMLHttpRequestUpload;
```MDN (the Mozilla Developer Network) has a
[great intro to XMLHttpRequest](https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest/Using_XMLHttpRequest).This library's [CoffeeDocs](http://coffeedoc.info/github/pwnall/node-xhr2/) can
be used as quick reference to the XMLHttpRequest specification parts that were
implemented.## Features
The following standard features are implemented.
* `http` and `https` URI protocols
* Basic authentication according to the XMLHttpRequest specification
* request and response header management
* `send()` accepts the following data types: String, ArrayBufferView,
ArrayBuffer (deprecated in the standard)
* `responseType` values: `text`, `json`, `arraybuffer`
* `readystatechange` and download progress events
* `overrideMimeType()`
* `abort()`
* `timeout`
* automated redirection followingThe following node.js extensions are implemented.
* `send()` accepts a node.js Buffer
* Setting `responseType` to `buffer` produces a node.js Buffer
* `nodejsSet` does XHR network configuration that is not exposed in browsers,
for security reasonsThe following standard features are not implemented.
* FormData
* Blob
* `file://` URIs
* `data:` URIs
* upload progress events
* synchronous operation
* Same-origin policy checks and CORS
* cookie processing## Versioning
The library aims to implement the
[W3C XMLHttpRequest](http://www.w3.org/TR/XMLHttpRequest/) specification, so
the library's API will always be a (hopefully growing) subset of the API in the
specification.## Development
The following commands will get the source tree in a `node-xhr2/` directory and
build the library.```bash
git clone git://github.com/pwnall/node-xhr2.git
cd node-xhr2
npm install
npm pack
```Installing CoffeeScript globally will let you type `cake` instead of
`node_modules/.bin/cake````bash
npm install -g coffeescript
```The library comes with unit tests that exercise the XMLHttpRequest API.
```bash
cake test
```The tests themselves can be tested by running them in a browser environment,
where a different XMLHttpRequest implementation is available. Both Google
Chrome and Firefox deviate from the specification in small ways, so it's best
to run the tests in both browsers and mentally compute an intersection of the
failing tests.```bash
cake webtest
BROWSER=firefox cake webtest
```## Copyright and License
The library is Copyright (c) 2013 Victor Costan, and distributed under the MIT
License.