Skip to content
This repository has been archived by the owner on Apr 22, 2023. It is now read-only.

Commit

Permalink
tls, https: throw exception on missing key/cert
Browse files Browse the repository at this point in the history
Throw an exception in the tls.Server constructor when the options object
doesn't contain either a PFX or a key/certificate combo.

Said change exposed a bug in simple/test-tls-junk-closes-server. Addressed.

Fixes #3941.
  • Loading branch information
bnoordhuis committed Aug 29, 2012
1 parent e4cef1a commit 8bec261
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 1 deletion.
4 changes: 4 additions & 0 deletions lib/tls.js
Expand Up @@ -1058,6 +1058,10 @@ function Server(/* [options], listener */) {
// Handle option defaults:
this.setOptions(options);

if (!self.pfx && (!self.cert || !self.key)) {
throw new Error('Missing PFX or certificate + private key.');
}

var sharedCreds = crypto.createCredentials({
pfx: self.pfx,
key: self.key,
Expand Down
2 changes: 1 addition & 1 deletion test/simple/test-tls-junk-closes-server.js
Expand Up @@ -34,7 +34,7 @@ var options = {
cert: fs.readFileSync(common.fixturesDir + '/keys/agent2-cert.pem')
};

var server = tls.createServer(function(s) {
var server = tls.createServer(options, function(s) {
s.write('welcome!\n');
s.pipe(s);
});
Expand Down
38 changes: 38 additions & 0 deletions test/simple/test-tls-server-missing-options.js
@@ -0,0 +1,38 @@
// Copyright Joyent, Inc. and other Node contributors.
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to permit
// persons to whom the Software is furnished to do so, subject to the
// following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
// USE OR OTHER DEALINGS IN THE SOFTWARE.

if (!process.versions.openssl) {
console.error('Skipping because node compiled without OpenSSL.');
process.exit(0);
}

var common = require('../common');
var assert = require('assert');
var https = require('https');
var tls = require('tls');

assert.throws(function() {
tls.createServer({ /* empty */}).listen(0);
}, /missing.+certificate/i);

assert.throws(function() {
https.createServer({ /* empty */}).listen(0);
}, /missing.+certificate/i);

1 comment on commit 8bec261

@kgriffs
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice. Thanks!

Please sign in to comment.