Skip to content

Commit

Permalink
https: don't overwrite servername option
Browse files Browse the repository at this point in the history
PR-URL: #1110
Reviewed-By: Fedor Indutny <[email protected]>
Reviewed-By: Jeremiah Senkpiel <[email protected]>
  • Loading branch information
skenqbx authored and indutny committed Mar 11, 2015
1 parent 60dac07 commit 8453fbc
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 5 deletions.
12 changes: 7 additions & 5 deletions lib/_http_agent.js
Original file line number Diff line number Diff line change
Expand Up @@ -160,11 +160,13 @@ Agent.prototype.createSocket = function(req, options) {
options = util._extend({}, options);
options = util._extend(options, self.options);

options.servername = options.host;
if (req) {
var hostHeader = req.getHeader('host');
if (hostHeader) {
options.servername = hostHeader.replace(/:.*$/, '');
if (!options.servername) {
options.servername = options.host;
if (req) {
var hostHeader = req.getHeader('host');
if (hostHeader) {
options.servername = hostHeader.replace(/:.*$/, '');
}
}
}

Expand Down
40 changes: 40 additions & 0 deletions test/parallel/test-https-agent-servername.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
var common = require('../common');
var assert = require('assert');

if (!common.hasCrypto) {
console.log('1..0 # Skipped: missing crypto');
process.exit();
}

var https = require('https');
var fs = require('fs');

var options = {
key: fs.readFileSync(common.fixturesDir + '/keys/agent1-key.pem'),
cert: fs.readFileSync(common.fixturesDir + '/keys/agent1-cert.pem'),
ca: fs.readFileSync(common.fixturesDir + '/keys/ca1-cert.pem')
};


var server = https.Server(options, function(req, res) {
res.writeHead(200);
res.end('hello world\n');
});


server.listen(common.PORT, function() {
https.get({
path: '/',
port: common.PORT,
rejectUnauthorized: true,
servername: 'agent1',
ca: options.ca
}, function(res) {
res.resume();
console.log(res.statusCode);
server.close();
}).on('error', function(e) {
console.log(e.message);
process.exit(1);
});
});

0 comments on commit 8453fbc

Please sign in to comment.