| 'use strict'; |
| |
| const tls = require('tls'); |
| const url = require('url'); |
| const http = require('http'); |
| const util = require('util'); |
| const inherits = util.inherits; |
| const debug = util.debuglog('https'); |
| |
| function Server(opts, requestListener) { |
| if (!(this instanceof Server)) return new Server(opts, requestListener); |
| |
| if (process.features.tls_npn && !opts.NPNProtocols) { |
| opts.NPNProtocols = ['http/1.1', 'http/1.0']; |
| } |
| |
| tls.Server.call(this, opts, http._connectionListener); |
| |
| this.httpAllowHalfOpen = false; |
| |
| if (requestListener) { |
| this.addListener('request', requestListener); |
| } |
| |
| this.addListener('clientError', function(err, conn) { |
| conn.destroy(); |
| }); |
| |
| this.timeout = 2 * 60 * 1000; |
| } |
| inherits(Server, tls.Server); |
| exports.Server = Server; |
| |
| Server.prototype.setTimeout = http.Server.prototype.setTimeout; |
| |
| exports.createServer = function(opts, requestListener) { |
| return new Server(opts, requestListener); |
| }; |
| |
| |
| // HTTPS agents. |
| |
| function createConnection(port, host, options) { |
| if (port !== null && typeof port === 'object') { |
| options = port; |
| } else if (host !== null && typeof host === 'object') { |
| options = host; |
| } else if (options === null || typeof options !== 'object') { |
| options = {}; |
| } |
| |
| if (typeof port === 'number') { |
| options.port = port; |
| } |
| |
| if (typeof host === 'string') { |
| options.host = host; |
| } |
| |
| debug('createConnection', options); |
| return tls.connect(options); |
| } |
| |
| |
| function Agent(options) { |
| http.Agent.call(this, options); |
| this.defaultPort = 443; |
| this.protocol = 'https:'; |
| } |
| inherits(Agent, http.Agent); |
| Agent.prototype.createConnection = createConnection; |
| |
| Agent.prototype.getName = function(options) { |
| var name = http.Agent.prototype.getName.call(this, options); |
| |
| name += ':'; |
| if (options.ca) |
| name += options.ca; |
| |
| name += ':'; |
| if (options.cert) |
| name += options.cert; |
| |
| name += ':'; |
| if (options.ciphers) |
| name += options.ciphers; |
| |
| name += ':'; |
| if (options.key) |
| name += options.key; |
| |
| name += ':'; |
| if (options.pfx) |
| name += options.pfx; |
| |
| name += ':'; |
| if (options.rejectUnauthorized !== undefined) |
| name += options.rejectUnauthorized; |
| |
| return name; |
| }; |
| |
| const globalAgent = new Agent(); |
| |
| exports.globalAgent = globalAgent; |
| exports.Agent = Agent; |
| |
| exports.request = function(options, cb) { |
| if (typeof options === 'string') { |
| options = url.parse(options); |
| } else { |
| options = util._extend({}, options); |
| } |
| options._defaultAgent = globalAgent; |
| return http.request(options, cb); |
| }; |
| |
| exports.get = function(options, cb) { |
| var req = exports.request(options, cb); |
| req.end(); |
| return req; |
| }; |