oneuptime/Probe/Config.ts
Nawaz Dhandala 2eec57befd
refactor(proxy-config): robust hostname/port extraction, normalize ports, and tidy formatting
- Improve extractHostnameAndPort and splitHostAndPort to handle IPv6 brackets, single-colon ports, and trimmed port values; return explicit result objects.
- Normalize host/port parsing logic and ensure port values are trimmed before use.
- Consolidate import formatting and split long method signatures for readability.
- Minor formatting/whitespace cleanups in Probe Config, Alive, Register, Monitor, and NO_PROXY parsing.
2025-10-24 15:12:12 +01:00

136 lines
4.1 KiB
TypeScript

import URL from "Common/Types/API/URL";
import ObjectID from "Common/Types/ObjectID";
import logger from "Common/Server/Utils/Logger";
import Port from "Common/Types/Port";
if (!process.env["PROBE_INGEST_URL"] && !process.env["ONEUPTIME_URL"]) {
logger.error("PROBE_INGEST_URL or ONEUPTIME_URL is not set");
process.exit();
}
export let PROBE_INGEST_URL: URL = URL.fromString(
process.env["ONEUPTIME_URL"] ||
process.env["PROBE_INGEST_URL"] ||
"https://oneuptime.com",
);
// If probe api does not have the path. Add it.
if (
!PROBE_INGEST_URL.toString().endsWith("probe-ingest") &&
!PROBE_INGEST_URL.toString().endsWith("probe-ingest/")
) {
PROBE_INGEST_URL = URL.fromString(
PROBE_INGEST_URL.addRoute("/probe-ingest").toString(),
);
}
export const PROBE_NAME: string | null = process.env["PROBE_NAME"] || null;
export const PROBE_DESCRIPTION: string | null =
process.env["PROBE_DESCRIPTION"] || null;
export const PROBE_ID: ObjectID | null = process.env["PROBE_ID"]
? new ObjectID(process.env["PROBE_ID"])
: null;
if (!process.env["PROBE_KEY"]) {
logger.error("PROBE_KEY is not set");
process.exit();
}
export const PROBE_KEY: string = process.env["PROBE_KEY"];
let probeMonitoringWorkers: string | number =
process.env["PROBE_MONITORING_WORKERS"] || 1;
if (typeof probeMonitoringWorkers === "string") {
probeMonitoringWorkers = parseInt(probeMonitoringWorkers);
}
export const PROBE_MONITORING_WORKERS: number = probeMonitoringWorkers;
let monitorFetchLimit: string | number =
process.env["PROBE_MONITOR_FETCH_LIMIT"] || 10;
if (typeof monitorFetchLimit === "string") {
monitorFetchLimit = parseInt(monitorFetchLimit);
}
export const PROBE_MONITOR_FETCH_LIMIT: number = monitorFetchLimit;
export const HOSTNAME: string = process.env["HOSTNAME"] || "localhost";
export const PROBE_SYNTHETIC_MONITOR_SCRIPT_TIMEOUT_IN_MS: number = process.env[
"PROBE_SYNTHETIC_MONITOR_SCRIPT_TIMEOUT_IN_MS"
]
? parseInt(
process.env["PROBE_SYNTHETIC_MONITOR_SCRIPT_TIMEOUT_IN_MS"].toString(),
)
: 60000;
export const PROBE_CUSTOM_CODE_MONITOR_SCRIPT_TIMEOUT_IN_MS: number = process
.env["PROBE_CUSTOM_CODE_MONITOR_SCRIPT_TIMEOUT_IN_MS"]
? parseInt(
process.env["PROBE_CUSTOM_CODE_MONITOR_SCRIPT_TIMEOUT_IN_MS"].toString(),
)
: 60000;
export const PROBE_MONITOR_RETRY_LIMIT: number = process.env[
"PROBE_MONITOR_RETRY_LIMIT"
]
? parseInt(process.env["PROBE_MONITOR_RETRY_LIMIT"].toString())
: 3;
export const PORT: Port = new Port(
process.env["PORT"] ? parseInt(process.env["PORT"]) : 3874,
);
/*
* Proxy configuration for all HTTP/HTTPS requests made by the probe
* HTTP_PROXY_URL: Proxy for HTTP requests
* Format: http://[username:password@]proxy.example.com:port
* Example: http://proxy.example.com:8080
* Example with auth: http://user:pass@proxy.example.com:8080
*/
export const HTTP_PROXY_URL: string | null =
process.env["HTTP_PROXY_URL"] || process.env["http_proxy"] || null;
/*
* HTTPS_PROXY_URL: Proxy for HTTPS requests
* Format: http://[username:password@]proxy.example.com:port
* Example: http://proxy.example.com:8080
* Example with auth: http://user:pass@proxy.example.com:8080
*/
export const HTTPS_PROXY_URL: string | null =
process.env["HTTPS_PROXY_URL"] || process.env["https_proxy"] || null;
/*
* NO_PROXY: Comma-separated list of hosts that should bypass the configured proxy.
* Hosts can include optional ports (example.com:8080) or leading dots for subdomains (.example.com).
*/
const rawNoProxy: string | undefined =
process.env["NO_PROXY"] || process.env["no_proxy"] || undefined;
export const NO_PROXY: Array<string> = rawNoProxy
? rawNoProxy
.split(",")
.map((value: string) => {
return value.trim();
})
.reduce<Array<string>>((accumulator: Array<string>, current: string) => {
if (!current) {
return accumulator;
}
const parts: Array<string> = current
.split(/\s+/)
.map((item: string) => {
return item.trim();
})
.filter((item: string) => {
return item.length > 0;
});
return accumulator.concat(parts);
}, [])
: [];