-
Notifications
You must be signed in to change notification settings - Fork 1
/
server.js
53 lines (50 loc) · 1.71 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
// Listen on a specific host via the HOST environment variable
var host = process.env.HOST || "0.0.0.0";
// Listen on a specific port via the PORT environment variable
var port = process.env.PORT || 8080;
// Grab the blacklist from the command-line so that we can update the blacklist without deploying
// again. CORS Anywhere is open by design, and this blacklist is not used, except for countering
// immediate abuse (e.g. denial of service). If you want to block all origins except for some,
// use originWhitelist instead.
var originBlacklist = parseEnvList(process.env.CORSANYWHERE_BLACKLIST);
var originWhitelist = parseEnvList(process.env.CORSANYWHERE_WHITELIST);
function parseEnvList(env) {
if (!env) {
return [];
}
return env.split(",");
}
// Set up rate-limiting to avoid abuse of the public CORS Anywhere server.
var checkRateLimit = require("./lib/rate-limit")(
process.env.CORSANYWHERE_RATELIMIT
);
var cors_proxy = require("./lib/cors-anywhere");
cors_proxy
.createServer({
originBlacklist: originBlacklist,
originWhitelist: originWhitelist,
requireHeader: [],
checkRateLimit: checkRateLimit,
removeHeaders: [
"cookie",
"cookie2",
// Strip Heroku-specific headers
"x-request-start",
"x-request-id",
"via",
"connect-time",
"total-route-time",
// Other Heroku added debug headers
// 'x-forwarded-for',
// 'x-forwarded-proto',
// 'x-forwarded-port',
],
redirectSameOrigin: true,
httpProxyOptions: {
// Do not add X-Forwarded-For, etc. headers, because Heroku already adds it.
xfwd: false,
},
})
.listen(port, host, function () {
console.log("Running CORS Anywhere on " + host + ":" + port);
});