forked from serverless-dns/serverless-dns
-
Notifications
You must be signed in to change notification settings - Fork 0
/
config.js
59 lines (51 loc) · 1.95 KB
/
config.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
/*
* Copyright (c) 2021 RethinkDNS and its authors.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
import EnvManager from "../env.js";
import * as system from "../../system.js";
import Log from "../log.js";
import { services } from "../svc.js";
((main) => {
system.when("prepare").then(prep);
system.when("steady").then(up);
})();
// on Workers, setup is called for every new request,
// since server-workers.js fires "prepare" on every request
function prep(arg) {
// if this file execs... assume we're on workers.
if (!arg) throw new Error("are we on workers?");
if (!arg.env) throw new Error("workers cannot be setup with empty env");
// okay to attach env to global, as env across requests remains the same
// developers.cloudflare.com/workers/runtime-apis/fetch-event/#parameters
globalThis.wenv = arg.env;
if (!globalThis.envManager) {
globalThis.envManager = new EnvManager();
}
const isProd = wenv.WORKER_ENV === "production";
if (!globalThis.log) {
globalThis.log = new Log({
level: envManager.get("LOG_LEVEL"),
levelize: isProd, // levelize only in prod
withTimestamps: false, // no need to log ts on workers
});
}
// on Workers, the network-context isn't available in global-scope
// ie network requests, for ex over fetch-api or xhr, don't work.
// And so, system ready event is published by the event listener
// which has the network-context, that is necessary for svc.js
// to setup blocklist-filter, which otherwise fails when invoked
// from global-scope (such as the "main" function in this file).
system.pub("ready", { env: arg.env });
}
function up() {
if (!services.ready) {
log.e("services not yet ready, and we've got a sig-up?!");
return;
}
// nothing else to do on sig-up on Workers; fire a sig-go!
system.pub("go");
}