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'),
|
2015-02-10 12:03:21 +08:00
|
|
|
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"),
|
2015-03-23 10:20:04 +08:00
|
|
|
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;
|
|
|
|
|
2015-02-10 12:03:21 +08:00
|
|
|
//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({
|
2015-02-10 12:03:21 +08:00
|
|
|
key :keyContent,
|
|
|
|
cert :crtContent
|
|
|
|
});
|
|
|
|
callback();
|
|
|
|
}catch(e){
|
|
|
|
callback(e);
|
|
|
|
}
|
2014-08-11 16:43:14 +08:00
|
|
|
}
|
2015-02-10 12:03:21 +08:00
|
|
|
],function(err,result){
|
|
|
|
if(!err){
|
|
|
|
var tipText = "proxy server for __NAME established".replace("__NAME",serverName);
|
2015-03-23 10:20:04 +08:00
|
|
|
logUtil.printLog(color.yellow(color.bold("[internal https]")) + color.yellow(tipText));
|
2015-02-10 12:03:21 +08:00
|
|
|
SNICallback(null,ctx);
|
2014-08-11 16:43:14 +08:00
|
|
|
}else{
|
2015-03-23 10:20:04 +08:00
|
|
|
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);
|
2015-06-18 20:23:42 +08:00
|
|
|
logUtil.printLog("you may upgrade your Node.js to >= v0.12", logUtil.T_ERR);
|
2014-08-11 16:43:14 +08:00
|
|
|
}
|
2015-02-10 12:03:21 +08:00
|
|
|
});
|
|
|
|
}
|
2014-08-11 16:43:14 +08:00
|
|
|
|
2015-02-10 12:03:21 +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
|
|
|
|
2015-02-10 12:03:21 +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
|
|
|
}
|
|
|
|
|
|
|
|
|