From 5e3b0095de96469a65f6e789e0d2b54d76711463 Mon Sep 17 00:00:00 2001 From: Ben Noordhuis Date: Wed, 16 Nov 2011 23:54:43 +0100 Subject: [PATCH 1/7] tls: make cipher list configurable options.ciphers existed but didn't work, the cipher list was effectively hard-coded to RC4-SHA:AES128-SHA:AES256-SHA. Fixes #2066. --- lib/tls.js | 5 +-- test/simple/test-tls-set-ciphers.js | 61 +++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+), 4 deletions(-) create mode 100644 test/simple/test-tls-set-ciphers.js diff --git a/lib/tls.js b/lib/tls.js index 21bb2af0721..8f83ecf9865 100644 --- a/lib/tls.js +++ b/lib/tls.js @@ -849,15 +849,13 @@ function Server(/* [options], listener */) { passphrase: self.passphrase, cert: self.cert, ca: self.ca, - ciphers: self.ciphers, + ciphers: self.ciphers || 'RC4-SHA:AES128-SHA:AES256-SHA', secureProtocol: self.secureProtocol, secureOptions: self.secureOptions, crl: self.crl, sessionIdContext: self.sessionIdContext }); - sharedCreds.context.setCiphers('RC4-SHA:AES128-SHA:AES256-SHA'); - // constructor call net.Server.call(this, function(socket) { var creds = crypto.createCredentials(null, sharedCreds.context); @@ -1017,7 +1015,6 @@ exports.connect = function(port /* host, options, cb */) { var socket = new net.Stream(); var sslcontext = crypto.createCredentials(options); - //sslcontext.context.setCiphers('RC4-SHA:AES128-SHA:AES256-SHA'); convertNPNProtocols(options.NPNProtocols, this); var pair = new SecurePair(sslcontext, false, true, false, diff --git a/test/simple/test-tls-set-ciphers.js b/test/simple/test-tls-set-ciphers.js new file mode 100644 index 00000000000..ba5c868d12c --- /dev/null +++ b/test/simple/test-tls-set-ciphers.js @@ -0,0 +1,61 @@ +// 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. + +var common = require('../common'); +var assert = require('assert'); +var exec = require('child_process').exec; +var tls = require('tls'); +var fs = require('fs'); + +if (process.platform === 'win32') { + console.log("Skipping test, you probably don't have openssl installed."); + process.exit(); +} + +var options = { + key: fs.readFileSync(common.fixturesDir + '/keys/agent2-key.pem'), + cert: fs.readFileSync(common.fixturesDir + '/keys/agent2-cert.pem'), + ciphers: 'NULL-MD5' // it's ultra-fast! +}; + +var reply = 'I AM THE WALRUS'; // something recognizable +var nconns = 0; +var response = ''; + +process.on('exit', function() { + assert.equal(nconns, 1); + assert.notEqual(response.indexOf(reply), -1); +}); + +var server = tls.createServer(options, function(conn) { + conn.end(reply); + nconns++; +}); + +server.listen(common.PORT, '127.0.0.1', function() { + var cmd = 'openssl s_client -cipher NULL-MD5 -connect 127.0.0.1:' + common.PORT; + + exec(cmd, function(err, stdout, stderr) { + if (err) throw err; + response = stdout; + server.close(); + }); +}); From 9c70b09e0ac959208f436d14d77ef12b89f68ef4 Mon Sep 17 00:00:00 2001 From: Bert Belder Date: Thu, 17 Nov 2011 00:10:14 +0100 Subject: [PATCH 2/7] Fix strange vcbuild "label not found" error --- vcbuild.bat | 2 ++ 1 file changed, 2 insertions(+) diff --git a/vcbuild.bat b/vcbuild.bat index 4e092b2ce54..709d71ce7c3 100644 --- a/vcbuild.bat +++ b/vcbuild.bat @@ -37,6 +37,8 @@ if /i "%1"=="test-all" set test=test-all&goto arg-ok if /i "%1"=="test" set test=test&goto arg-ok if /i "%1"=="msi" set msi=1&goto arg-ok if /i "%1"=="upload" set upload=1&goto arg-ok + + :arg-ok shift goto next-arg From 3e696d189ca0b22f73baaf367a2a6327bc449ab9 Mon Sep 17 00:00:00 2001 From: Bert Belder Date: Thu, 17 Nov 2011 00:54:42 +0100 Subject: [PATCH 3/7] Windows: make Buffer and ObjectWrap available to compiled extensions Closes GH-2036 --- src/node_buffer.h | 2 +- src/node_object_wrap.h | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/node_buffer.h b/src/node_buffer.h index 2a93a1db679..ea3311245c6 100644 --- a/src/node_buffer.h +++ b/src/node_buffer.h @@ -63,7 +63,7 @@ namespace node { */ -class Buffer : public ObjectWrap { +class NODE_EXTERN Buffer: public ObjectWrap { public: static bool HasInstance(v8::Handle val); diff --git a/src/node_object_wrap.h b/src/node_object_wrap.h index 016d59578fb..d76dd594ab8 100644 --- a/src/node_object_wrap.h +++ b/src/node_object_wrap.h @@ -27,7 +27,7 @@ namespace node { -class ObjectWrap { +class NODE_EXTERN ObjectWrap { public: ObjectWrap ( ) { refs_ = 0; From 960ccdc72cefa9c7b9e588a1d149a1dba7a0c296 Mon Sep 17 00:00:00 2001 From: Artur Adib Date: Tue, 8 Nov 2011 21:13:59 -0500 Subject: [PATCH 4/7] docs: clarify addon docs --- doc/api/addons.markdown | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/doc/api/addons.markdown b/doc/api/addons.markdown index 3234e7a6082..3e815d4d44e 100644 --- a/doc/api/addons.markdown +++ b/doc/api/addons.markdown @@ -22,8 +22,8 @@ Node statically compiles all its dependencies into the executable. When compiling your module, you don't need to worry about linking to any of these libraries. -To get started let's make a small Addon which does the following except in -C++: +To get started let's make a small Addon which is the C++ equivalent of +the following Javascript code: exports.hello = function() { return 'world'; }; @@ -40,11 +40,18 @@ To get started we create a file `hello.cc`: } void init(Handle target) { - NODE_SET_METHOD(target, "method", Method); + NODE_SET_METHOD(target, "hello", Method); } NODE_MODULE(hello, init) -This source code needs to be built into `hello.node`, the binary Addon. To +Note that all Node addons must export an initialization function: + + void Initialize (Handle target); + NODE_MODULE(module_name, Initialize) + +There is no semi-colon after `NODE_MODULE` as it's not a function (see `node.h`). + +The source code needs to be built into `hello.node`, the binary Addon. To do this we create a file called `wscript` which is python code and looks like this: @@ -70,10 +77,12 @@ Running `node-waf configure build` will create a file `node-waf` is just [WAF](http://code.google.com/p/waf), the python-based build system. `node-waf` is provided for the ease of users. -All Node addons must export an initialization function: +You can now use the binary addon in a Node project `hello.js` by pointing `require` to +the recently built module: - void Initialize (Handle target); - NODE_MODULE(hello, Initialize) + var addon = require('./build/Release/hello'); + + console.log(addon.hello()); // 'world' For the moment, that is all the documentation on addons. Please see for a real example. From 2c52ccea80e74d813ba678ad2f39bd2079c73bf7 Mon Sep 17 00:00:00 2001 From: Ben Noordhuis Date: Fri, 2 Sep 2011 14:39:04 +0000 Subject: [PATCH 5/7] v8: compile with __C99FEATURES__=1 on sunos Exposes INFINITY, isinf(), isfinite(), etc. Re-applies d104e5b91cfa3ef3ef846d5a0ab07c0336263a92, lost in a V8 upgrade. --- deps/v8/tools/gyp/v8-node.gyp | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/deps/v8/tools/gyp/v8-node.gyp b/deps/v8/tools/gyp/v8-node.gyp index 3b067a5f560..f2b3a337bd8 100644 --- a/deps/v8/tools/gyp/v8-node.gyp +++ b/deps/v8/tools/gyp/v8-node.gyp @@ -3,4 +3,11 @@ '../../build/common.gypi', 'v8.gyp' ], + 'target_defaults': { + 'conditions': [ + [ 'OS=="solaris"', { + 'defines': [ '__C99FEATURES__=1' ], + }], + ], + }, } From 4f8a0cd2f9d92135fe6e9e94229d1332dff3e0e0 Mon Sep 17 00:00:00 2001 From: Ben Noordhuis Date: Fri, 2 Sep 2011 14:39:44 +0000 Subject: [PATCH 6/7] v8: add platform-solaris.cc to gyp build Re-applies 77e4abbc3e66505af89c57cd7bff555890a33f3f, lost in a V8 upgrade. --- deps/v8/tools/gyp/v8.gyp | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/deps/v8/tools/gyp/v8.gyp b/deps/v8/tools/gyp/v8.gyp index 50144172a04..92d1e5c96a6 100644 --- a/deps/v8/tools/gyp/v8.gyp +++ b/deps/v8/tools/gyp/v8.gyp @@ -641,6 +641,13 @@ ], } ], + ['OS=="solaris"', { + 'sources': [ + '../../src/platform-solaris.cc', + '../../src/platform-posix.cc' + ], + } + ], ['OS=="mac"', { 'sources': [ '../../src/platform-macos.cc', From b0030af13566e22cca289595a7e80b76f5e2c2f2 Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Thu, 17 Nov 2011 11:39:14 -0800 Subject: [PATCH 7/7] Fixes #2140. Fix illumos build. --- src/node.h | 1 + src/node_object_wrap.h | 1 + 2 files changed, 2 insertions(+) diff --git a/src/node.h b/src/node.h index 1d322370d19..cb58a220bbe 100644 --- a/src/node.h +++ b/src/node.h @@ -62,6 +62,7 @@ #include #include /* struct stat */ #include +#include #include diff --git a/src/node_object_wrap.h b/src/node_object_wrap.h index d76dd594ab8..0ead639b645 100644 --- a/src/node_object_wrap.h +++ b/src/node_object_wrap.h @@ -22,6 +22,7 @@ #ifndef object_wrap_h #define object_wrap_h +#include #include #include