This repository has been archived by the owner on Mar 28, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathenv.js
78 lines (67 loc) · 3.42 KB
/
env.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/*
* Copyright (c) 2014, Tidepool Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this
* list of conditions and the following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
var fs = require('fs');
var amoeba = require('amoeba');
var config = amoeba.config;
var except = amoeba.except;
function maybeReplaceWithContentsOfFile(obj, field)
{
var potentialFile = obj[field];
if (potentialFile != null && fs.existsSync(potentialFile)) {
obj[field] = fs.readFileSync(potentialFile).toString();
}
}
module.exports = (function(){
var env = {};
// The port to attach an HTTP listener, if null, no HTTP listener will be attached
env.httpPort = config.fromEnvironment('HTTP_PORT', null);
// The port to attach an HTTPS listener, if null, no HTTPS listener will be attached
env.httpsPort = config.fromEnvironment('HTTPS_PORT', null);
// The https config to pass along to https.createServer.
var theConfig = config.fromEnvironment('HTTPS_CONFIG', null);
env.httpsConfig = null;
if (theConfig != null) {
env.httpsConfig = JSON.parse(theConfig);
maybeReplaceWithContentsOfFile(env.httpsConfig, 'key');
maybeReplaceWithContentsOfFile(env.httpsConfig, 'cert');
maybeReplaceWithContentsOfFile(env.httpsConfig, 'pfx');
}
if (env.httpsPort != null && env.httpsConfig == null) {
throw except.ISE('No https config provided, please set HTTPS_CONFIG with at least the certificate to use.');
}
// A JSON object of domain -> JSON Array of rules. Domains ignore case and must be exact.
// The domain "*" is a catchall for everything that didn't match a specific domain.
//
// The rules are applied by first taking the value of the Host: header, looking up the correct
// set of rules for the specific host and then running through the rules until it finds a rule
// that covers the request. The request is then completely delegated to that rule.
env.rules = JSON.parse(config.fromEnvironment('RULES'));
// A JSON object of discovery configuration. This is a straight passthru to hakken's config
env.discovery = JSON.parse(config.fromEnvironment('DISCOVERY'));
// A JSON object of proxying. This is a straight passthru to http-proxy.createServer()
env.proxyConfig = JSON.parse(config.fromEnvironment('PROXY_CONFIG', '{}'));
return env;
})();