mirror of
https://github.com/louislam/uptime-kuma.git
synced 2024-11-23 23:04:04 +00:00
Compare commits
7 commits
3a23b201f5
...
3d21b3e567
Author | SHA1 | Date | |
---|---|---|---|
|
3d21b3e567 | ||
|
6899603eb7 | ||
|
cfc69e69e8 | ||
|
ad71fc9481 | ||
|
8160930470 | ||
|
727651b4ae | ||
|
f1430ec6af |
4 changed files with 66 additions and 4 deletions
40
package-lock.json
generated
40
package-lock.json
generated
|
@ -30,6 +30,7 @@
|
|||
"dotenv": "~16.0.3",
|
||||
"express": "~4.21.0",
|
||||
"express-basic-auth": "~1.2.1",
|
||||
"express-ipfilter": "^1.3.1",
|
||||
"express-static-gzip": "~2.1.7",
|
||||
"feed": "^4.2.2",
|
||||
"form-data": "~4.0.0",
|
||||
|
@ -8605,6 +8606,25 @@
|
|||
"basic-auth": "^2.0.1"
|
||||
}
|
||||
},
|
||||
"node_modules/express-ipfilter": {
|
||||
"version": "1.3.1",
|
||||
"resolved": "https://registry.npmjs.org/express-ipfilter/-/express-ipfilter-1.3.1.tgz",
|
||||
"integrity": "sha512-9WZC8wGkI6I6ygZNzuZ2MbFJiGoDXs1dM+E8LKtSP13pdgqrnkonWlgvvbxG3YZpa7Haz7Ndum9/J6qkj52OqA==",
|
||||
"dependencies": {
|
||||
"ip": "^1.1.8",
|
||||
"lodash": "^4.17.11",
|
||||
"proxy-addr": "^2.0.7",
|
||||
"range_check": "^2.0.4"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=8.9.0"
|
||||
}
|
||||
},
|
||||
"node_modules/express-ipfilter/node_modules/ip": {
|
||||
"version": "1.1.8",
|
||||
"resolved": "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz",
|
||||
"integrity": "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg=="
|
||||
},
|
||||
"node_modules/express-static-gzip": {
|
||||
"version": "2.1.8",
|
||||
"resolved": "https://registry.npmjs.org/express-static-gzip/-/express-static-gzip-2.1.8.tgz",
|
||||
|
@ -10196,6 +10216,14 @@
|
|||
"node": ">= 12"
|
||||
}
|
||||
},
|
||||
"node_modules/ip6": {
|
||||
"version": "0.2.10",
|
||||
"resolved": "https://registry.npmjs.org/ip6/-/ip6-0.2.10.tgz",
|
||||
"integrity": "sha512-1LdpyKjhvepd6EbAU6rW4g14vuYtx5TnJX9TfZZBhsM6DsyPQLNzW12rtbUqXBMwqFrLVV/Gcxv0GNFvJp2cYA==",
|
||||
"bin": {
|
||||
"ip6": "ip6-cli.js"
|
||||
}
|
||||
},
|
||||
"node_modules/ipaddr.js": {
|
||||
"version": "1.9.1",
|
||||
"resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
|
||||
|
@ -13609,6 +13637,18 @@
|
|||
"node": ">=0.8.0"
|
||||
}
|
||||
},
|
||||
"node_modules/range_check": {
|
||||
"version": "2.0.4",
|
||||
"resolved": "https://registry.npmjs.org/range_check/-/range_check-2.0.4.tgz",
|
||||
"integrity": "sha512-aed0ocXXj+SIiNNN9b+mZWA3Ow2GXHtftOGk2xQwshK5GbEZAvUcPWNQBLTx/lPcdFRIUFlFCRtHTQNIFMqynQ==",
|
||||
"dependencies": {
|
||||
"ip6": "^0.2.0",
|
||||
"ipaddr.js": "^1.9.1"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=10.0.0"
|
||||
}
|
||||
},
|
||||
"node_modules/range-parser": {
|
||||
"version": "1.2.1",
|
||||
"resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
|
||||
|
|
|
@ -88,6 +88,7 @@
|
|||
"dotenv": "~16.0.3",
|
||||
"express": "~4.21.0",
|
||||
"express-basic-auth": "~1.2.1",
|
||||
"express-ipfilter": "^1.3.1",
|
||||
"express-static-gzip": "~2.1.7",
|
||||
"feed": "^4.2.2",
|
||||
"form-data": "~4.0.0",
|
||||
|
|
|
@ -119,6 +119,27 @@ const port = config.port;
|
|||
const disableFrameSameOrigin = !!process.env.UPTIME_KUMA_DISABLE_FRAME_SAMEORIGIN || args["disable-frame-sameorigin"] || false;
|
||||
const cloudflaredToken = args["cloudflared-token"] || process.env.UPTIME_KUMA_CLOUDFLARED_TOKEN || undefined;
|
||||
|
||||
const ipsToAllow = process.env.UPTIME_KUMA_IPS_TO_ALLOW || args["ips-to-allow"] || undefined;
|
||||
if (ipsToAllow !== undefined) {
|
||||
if (typeof ipsToAllow !== "string") {
|
||||
log.error("server", "IPs to allow must be a string, " + typeof ipsToAllow + " provided");
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
const splitIps = ipsToAllow.split(",");
|
||||
const net = require("net");
|
||||
for (const ip of splitIps) {
|
||||
if (net.isIP(ip) === 0) {
|
||||
log.error("server", "Provided IPs to allow must be valid IP addresses, " + ip + " provided");
|
||||
process.exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
log.info("server", "IPs to allow: " + splitIps);
|
||||
const ipfilter = require("express-ipfilter").IpFilter;
|
||||
app.use(ipfilter(splitIps, { mode: "allow" }));
|
||||
}
|
||||
|
||||
// 2FA / notp verification defaults
|
||||
const twoFAVerifyOptions = {
|
||||
"window": 1,
|
||||
|
|
|
@ -5,20 +5,20 @@
|
|||
</div>
|
||||
<div class="mb-3">
|
||||
<label for="sendgrid-from-email" class="form-label">{{ $t("From Email") }}</label>
|
||||
<input id="sendgrid-from-email" v-model="$parent.notification.sendgridFromEmail" type="email" class="form-control" required>
|
||||
<input id="sendgrid-from-email" v-model="$parent.notification.sendgridFromEmail" type="text" class="form-control" required>
|
||||
</div>
|
||||
<div class="mb-3">
|
||||
<label for="sendgrid-to-email" class="form-label">{{ $t("To Email") }}</label>
|
||||
<input id="sendgrid-to-email" v-model="$parent.notification.sendgridToEmail" type="email" class="form-control" required>
|
||||
<input id="sendgrid-to-email" v-model="$parent.notification.sendgridToEmail" type="text" class="form-control" required>
|
||||
</div>
|
||||
<div class="mb-3">
|
||||
<label for="sendgrid-cc-email" class="form-label">{{ $t("smtpCC") }}</label>
|
||||
<input id="sendgrid-cc-email" v-model="$parent.notification.sendgridCcEmail" type="email" class="form-control">
|
||||
<input id="sendgrid-cc-email" v-model="$parent.notification.sendgridCcEmail" type="text" class="form-control">
|
||||
<div class="form-text">{{ $t("Separate multiple email addresses with commas") }}</div>
|
||||
</div>
|
||||
<div class="mb-3">
|
||||
<label for="sendgrid-bcc-email" class="form-label">{{ $t("smtpBCC") }}</label>
|
||||
<input id="sendgrid-bcc-email" v-model="$parent.notification.sendgridBccEmail" type="email" class="form-control">
|
||||
<input id="sendgrid-bcc-email" v-model="$parent.notification.sendgridBccEmail" type="text" class="form-control">
|
||||
<small class="form-text text-muted">{{ $t("Separate multiple email addresses with commas") }}</small>
|
||||
</div>
|
||||
<div class="mb-3">
|
||||
|
|
Loading…
Reference in a new issue