mirror of
https://github.com/alibaba/anyproxy.git
synced 2025-04-22 10:11:26 +00:00
90 lines
2.4 KiB
JavaScript
90 lines
2.4 KiB
JavaScript
var isRootCAFileExists = require("./certMgr.js").isRootCAFileExists();
|
|
|
|
module.exports = {
|
|
summary:function(){
|
|
var tip = "the default rule for anyproxy, support : CORS. ";
|
|
if(isRootCAFileExists){
|
|
tip += "\nRoot CA exists, will intercept all https requests.";
|
|
}
|
|
return tip;
|
|
},
|
|
|
|
shouldUseLocalResponse : function(req,reqBody){
|
|
//intercept all options request
|
|
if(req.method == "OPTIONS"){
|
|
return true;
|
|
}else{
|
|
return false;
|
|
}
|
|
},
|
|
|
|
dealLocalResponse : function(req,reqBody,callback){
|
|
if(req.method == "OPTIONS"){
|
|
callback(200,mergeCORSHeader(req.headers),"");
|
|
}
|
|
},
|
|
|
|
replaceRequestProtocol:function(req,protocol){
|
|
},
|
|
|
|
replaceRequestOption : function(req,option){
|
|
},
|
|
|
|
replaceRequestData: function(req,data){
|
|
},
|
|
|
|
replaceResponseStatusCode: function(req,res,statusCode){
|
|
},
|
|
|
|
replaceResponseHeader: function(req,res,header){
|
|
return mergeCORSHeader(req.headers, header);
|
|
},
|
|
|
|
// Deprecated
|
|
// replaceServerResData: function(req,res,serverResData){
|
|
// return serverResData;
|
|
// },
|
|
|
|
replaceServerResDataAsync: function(req,res,serverResData,callback){
|
|
callback(serverResData);
|
|
},
|
|
|
|
pauseBeforeSendingResponse: function(req,res){
|
|
},
|
|
|
|
shouldInterceptHttpsReq:function(req){
|
|
// return false;
|
|
return isRootCAFileExists;
|
|
},
|
|
|
|
//[beta]
|
|
//fetch entire traffic data
|
|
fetchTrafficData: function(id,info){},
|
|
|
|
customMenu:[
|
|
{
|
|
name :"test",
|
|
handler :function(){}
|
|
},{
|
|
name :"second-test",
|
|
handler :function(){}
|
|
}
|
|
]
|
|
|
|
};
|
|
|
|
function mergeCORSHeader(reqHeader,originHeader){
|
|
var targetObj = originHeader || {};
|
|
|
|
delete targetObj["Access-Control-Allow-Credentials"];
|
|
delete targetObj["Access-Control-Allow-Origin"];
|
|
delete targetObj["Access-Control-Allow-Methods"];
|
|
delete targetObj["Access-Control-Allow-Headers"];
|
|
|
|
targetObj["access-control-allow-credentials"] = "true";
|
|
targetObj["access-control-allow-origin"] = reqHeader['origin'] || reqHeader['Origin'] || "-___-||";
|
|
targetObj["access-control-allow-methods"] = "GET, POST, PUT";
|
|
targetObj["access-control-allow-headers"] = reqHeader['access-control-request-headers'] || "-___-||";
|
|
|
|
return targetObj;
|
|
} |