diff --git a/lib/_tls_wrap.js b/lib/_tls_wrap.js index 2fd13ef83d..fcc216bf28 100644 --- a/lib/_tls_wrap.js +++ b/lib/_tls_wrap.js @@ -271,6 +271,14 @@ var proxiedMethods = [ 'setPendingInstances' ]; +// Proxy HandleWrap, PipeWrap and TCPWrap methods +proxiedMethods.forEach(function(name) { + tls_wrap.TLSWrap.prototype[name] = function methodProxy() { + if (this._parent[name]) + return this._parent[name].apply(this._parent, arguments); + }; +}); + TLSSocket.prototype._wrapHandle = function(handle) { var res; @@ -297,14 +305,6 @@ TLSSocket.prototype._wrapHandle = function(handle) { } }); - // Proxy HandleWrap, PipeWrap and TCPWrap methods - proxiedMethods.forEach(function(name) { - res[name] = function methodProxy() { - if (handle[name]) - return handle[name].apply(handle, arguments); - }; - }); - return res; }; diff --git a/src/tls_wrap.cc b/src/tls_wrap.cc index 8ecf33a75a..49523bc3b8 100644 --- a/src/tls_wrap.cc +++ b/src/tls_wrap.cc @@ -809,8 +809,8 @@ int TLSWrap::SelectSNIContextCallback(SSL* s, int* ad, void* arg) { void TLSWrap::Initialize(Handle target, - Handle unused, - Handle context) { + Handle unused, + Handle context) { Environment* env = Environment::GetCurrent(context); env->SetMethod(target, "wrap", TLSWrap::Wrap); @@ -835,6 +835,9 @@ void TLSWrap::Initialize(Handle target, env->set_tls_wrap_constructor_template(t); env->set_tls_wrap_constructor_function(t->GetFunction()); + + target->Set(FIXED_ONE_BYTE_STRING(env->isolate(), "TLSWrap"), + t->GetFunction()); } } // namespace node