@uphold/request-logger
Version:
A wrapper for the request module that logs all request events
102 lines (69 loc) • 3.85 kB
Markdown
A wrapper for the [request](https://github.com/cypress-io/request) module that logs all request events.
[![npm version][npm-image]][npm-url] [![build status][travis-image]][travis-url]
Install the package via **yarn**:
```shell
❯ yarn add '@uphold/request-logger'
```
Or via **npm**:
```shell
❯ npm install '@uphold/request-logger' --save
```
Wrap the `request` module using `@uphold/request-logger`. By default, all events will be logged to `stdout`.
```javascript
const logger = require('@uphold/request-logger');
const request = logger(require('@cypress/request'));
request.get('https://www.github.com');
// { headers: …,
// id: '6bfc21a0-0dad-48b2-8378-762e5f85f014',
// method: 'GET',
// type: 'request',
// uri: 'https://www.github.com/' }
// { headers: …,
// id: '6bfc21a0-0dad-48b2-8378-762e5f85f014',
// statusCode: 301,
// type: 'redirect',
// uri: 'https://github.com/' }
// { headers: …,
// id: '6bfc21a0-0dad-48b2-8378-762e5f85f014',
// method: 'GET',
// type: 'request',
// uri: 'https://github.com/' }
// { headers: …,
// id: '6bfc21a0-0dad-48b2-8378-762e5f85f014',
// statusCode: 200,
// type: 'response',
// uri: 'https://github.com/' }
```
You can optionally define a custom logging function which receives the request object (`data`) and the `request` instance:
```javascript
const logger = require('@uphold/request-logger');
const request = logger(require('@cypress/request'), data => console.log(`${data.id} ${data.type}: ${data.uri}${data.statusCode ? ` (${data.statusCode})` : ''} ${(data.body ? `${data.body}` : '').length} bytes`));
request.get('https://www.github.com', () => {});
// 8a3600f9-0995-4a89-951f-caf7c0a79a69 request: https://www.github.com/ 0 bytes
// 8a3600f9-0995-4a89-951f-caf7c0a79a69 redirect: https://github.com/ (301) 0 bytes
// 8a3600f9-0995-4a89-951f-caf7c0a79a69 request: https://github.com/ 0 bytes
// 8a3600f9-0995-4a89-951f-caf7c0a79a69 response: https://github.com/ (200) 25562 bytes
```
Each `data` object contains a `type` property indicating the type of event:
- **error** - the request has failed due to an error (e.g. a timeout). `data.error` is defined.
- **request** - the request succeeded. `data.body` may be defined for POST requests.
- **response** - the request returned a response. Note that `request` only buffers the response body if a callback was given, so only in that case will `data.body` be defined.
- **redirect** - the request received a redirect status code (_HTTP 3xx_). `data.uri` will point to the URI of the next request.
- **complete** - the request has been completed. This event is only dispatched on POST requests.
In every event, a `data.id` parameter is defined to allow matching it to the request it originated from.
## Compatibility
The recommended node.js version is `>= 6` as it ships with native [ES2015 Proxy](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Proxy) support. This module supports node.js `4` by means of a polyfill that is loaded under the hood. As usual, keep in mind that polyfills are not as performant as their native counterpart.
The minimum required `request` version is `2.27.0`, although `2.54.0` is a particularly troubled version which is best avoided.
The release of a version is automated via the [release](https://github.com/uphold/request-logger/.github/workflows/release.yaml) GitHub workflow.
Run it by clicking the "Run workflow" button.
MIT
[]: https://img.shields.io/npm/v/@uphold/request-logger.svg?style=flat-square
[]: https://npmjs.org/package/@uphold/request-logger
[]: https://img.shields.io/travis/uphold/request-logger.svg?style=flat-square
[]: https://travis-ci.org/uphold/request-logger