From 53b11e3539fb5859ae2fdae038b1e5a68af4a584 Mon Sep 17 00:00:00 2001 From: Dmitry Tsvettsikh Date: Thu, 22 Dec 2016 10:38:42 +0500 Subject: [PATCH] use `safe-buffer` (#253) --- .travis.yml | 1 + index.js | 11 ++--------- package.json | 1 + 3 files changed, 4 insertions(+), 9 deletions(-) diff --git a/.travis.yml b/.travis.yml index 8e2a51e..b4a9890 100644 --- a/.travis.yml +++ b/.travis.yml @@ -4,4 +4,5 @@ node_js: - '6' - '5' - '4' + - '4.4.4' after_success: npm run coveralls diff --git a/index.js b/index.js index 2f5bfb0..b623ccd 100644 --- a/index.js +++ b/index.js @@ -15,14 +15,9 @@ const isRedirect = require('is-redirect'); const unzipResponse = require('unzip-response'); const createErrorClass = require('create-error-class'); const isRetryAllowed = require('is-retry-allowed'); +const Buffer = require('safe-buffer').Buffer; const pkg = require('./package'); -const isModernBuffer = ( - typeof Buffer.alloc === 'function' && - typeof Buffer.allocUnsafe === 'function' && - typeof Buffer.from === 'function' -); - function requestAsEventEmitter(opts) { opts = opts || {}; @@ -46,9 +41,7 @@ function requestAsEventEmitter(opts) { return; } - const bufferString = isModernBuffer ? - Buffer.from(res.headers.location, 'binary').toString() : - new Buffer(res.headers.location, 'binary').toString(); + const bufferString = Buffer.from(res.headers.location, 'binary').toString(); redirectUrl = urlLib.resolve(urlLib.format(opts), bufferString); const redirectOpts = Object.assign({}, opts, urlLib.parse(redirectUrl)); diff --git a/package.json b/package.json index e59a422..6e500f2 100644 --- a/package.json +++ b/package.json @@ -52,6 +52,7 @@ "is-retry-allowed": "^1.0.0", "is-stream": "^1.0.0", "lowercase-keys": "^1.0.0", + "safe-buffer": "^5.0.1", "timed-out": "^3.0.0", "unzip-response": "^2.0.1", "url-parse-lax": "^1.0.0"