From 754df71a791fa0da985db795e6561cc3754c48b7 Mon Sep 17 00:00:00 2001 From: Bryan English Date: Sun, 22 Oct 2017 17:23:43 -0700 Subject: [PATCH] https: refactor to use http internals Rather than using `http`, use `_http_client`, etc. directly. Also moving all the exports to the bottom, in line with most of the rest of the codebase. PR-URL: https://github.com/nodejs/node/pull/16395 Reviewed-By: Anatoli Papirovski Reviewed-By: Colin Ihrig Reviewed-By: Luigi Pinca Reviewed-By: James M Snell --- lib/https.js | 46 ++++++++++++++++++++++++++++------------------ 1 file changed, 28 insertions(+), 18 deletions(-) diff --git a/lib/https.js b/lib/https.js index fb220872598315..56dd67088b7bb3 100644 --- a/lib/https.js +++ b/lib/https.js @@ -25,9 +25,14 @@ require('internal/util').assertCrypto(); const tls = require('tls'); const url = require('url'); -const http = require('http'); const util = require('util'); -const inherits = util.inherits; +const { Agent: HttpAgent } = require('_http_agent'); +const { + Server: HttpServer, + _connectionListener +} = require('_http_server'); +const { ClientRequest } = require('_http_client'); +const { inherits } = util; const debug = util.debuglog('https'); const { urlToOptions, searchParamsSymbol } = require('internal/url'); @@ -51,7 +56,7 @@ function Server(opts, requestListener) { opts.ALPNProtocols = ['http/1.1']; } - tls.Server.call(this, opts, http._connectionListener); + tls.Server.call(this, opts, _connectionListener); this.httpAllowHalfOpen = false; @@ -68,13 +73,12 @@ function Server(opts, requestListener) { this.keepAliveTimeout = 5000; } inherits(Server, tls.Server); -exports.Server = Server; -Server.prototype.setTimeout = http.Server.prototype.setTimeout; +Server.prototype.setTimeout = HttpServer.prototype.setTimeout; -exports.createServer = function createServer(opts, requestListener) { +function createServer(opts, requestListener) { return new Server(opts, requestListener); -}; +} // HTTPS agents. @@ -129,7 +133,7 @@ function Agent(options) { if (!(this instanceof Agent)) return new Agent(options); - http.Agent.call(this, options); + HttpAgent.call(this, options); this.defaultPort = 443; this.protocol = 'https:'; this.maxCachedSessions = this.options.maxCachedSessions; @@ -141,11 +145,11 @@ function Agent(options) { list: [] }; } -inherits(Agent, http.Agent); +inherits(Agent, HttpAgent); Agent.prototype.createConnection = createConnection; Agent.prototype.getName = function getName(options) { - var name = http.Agent.prototype.getName.call(this, options); + var name = HttpAgent.prototype.getName.call(this, options); name += ':'; if (options.ca) @@ -219,10 +223,7 @@ Agent.prototype._evictSession = function _evictSession(key) { const globalAgent = new Agent(); -exports.globalAgent = globalAgent; -exports.Agent = Agent; - -exports.request = function request(options, cb) { +function request(options, cb) { if (typeof options === 'string') { options = url.parse(options); if (!options.hostname) { @@ -236,11 +237,20 @@ exports.request = function request(options, cb) { options = util._extend({}, options); } options._defaultAgent = globalAgent; - return http.request(options, cb); -}; + return new ClientRequest(options, cb); +} -exports.get = function get(options, cb) { - var req = exports.request(options, cb); +function get(options, cb) { + const req = request(options, cb); req.end(); return req; +} + +module.exports = { + Agent, + globalAgent, + Server, + createServer, + get, + request };