anyproxy/lib/httpsServerMgr.js

78 lines
2.5 KiB
JavaScript
Raw Normal View History

2014-08-11 16:43:14 +08:00
//manage https servers
2014-08-13 13:27:05 +08:00
var getPort = require('./getPort'),
2014-08-11 16:43:14 +08:00
async = require("async"),
http = require('http'),
https = require('https'),
2016-05-02 00:18:35 +08:00
Buffer = require('buffer').Buffer,
2014-08-11 16:43:14 +08:00
fs = require('fs'),
net = require('net'),
tls = require('tls'),
2015-02-10 15:30:39 +08:00
crypto = require('crypto'),
2014-08-13 11:51:39 +08:00
color = require('colorful'),
2014-08-11 16:43:14 +08:00
certMgr = require("./certMgr"),
logUtil = require("./log"),
2014-08-13 17:30:16 +08:00
asyncTask = require("async-task-mgr");
2014-08-11 16:43:14 +08:00
2015-02-10 15:30:39 +08:00
var createSecureContext = tls.createSecureContext || crypto.createSecureContext;
//using sni to avoid multiple ports
function SNIPrepareCert(serverName,SNICallback){
var keyContent, crtContent,ctx;
async.series([
function(callback){
certMgr.getCertificate(serverName,function(err,key,crt){
if(err){
callback(err);
}else{
keyContent = key;
crtContent = crt;
callback();
}
});
},
function(callback){
try{
2015-02-10 15:30:39 +08:00
ctx = createSecureContext({
key :keyContent,
cert :crtContent
});
callback();
}catch(e){
callback(e);
}
2014-08-11 16:43:14 +08:00
}
],function(err,result){
if(!err){
var tipText = "proxy server for __NAME established".replace("__NAME",serverName);
logUtil.printLog(color.yellow(color.bold("[internal https]")) + color.yellow(tipText));
SNICallback(null,ctx);
2014-08-11 16:43:14 +08:00
}else{
logUtil.printLog("err occurred when prepare certs for SNI - " + err, logUtil.T_ERR);
2016-05-02 00:18:35 +08:00
logUtil.printLog("err occurred when prepare certs for SNI - " + err.stack, logUtil.T_ERR);
logUtil.printLog("you may upgrade your Node.js to >= v0.12", logUtil.T_ERR);
2014-08-11 16:43:14 +08:00
}
});
}
2014-08-11 16:43:14 +08:00
//config.port - port to start https server
//config.handler - request handler
module.exports =function(config){
var self = this;
2014-11-28 15:52:17 +08:00
if(!config || !config.port ){
throw(new Error("please assign a port"));
}
2014-08-11 16:43:14 +08:00
2015-02-10 15:30:39 +08:00
certMgr.getCertificate("anyproxy_internal_https_server",function(err,keyContent,crtContent){
https.createServer({
SNICallback : SNIPrepareCert ,
key : keyContent,
cert : crtContent
},config.handler).listen(config.port);
});
2014-08-11 16:43:14 +08:00
}