fix(cli): reject malformed timeout options

This commit is contained in:
Peter Steinberger
2026-05-24 01:03:58 +01:00
parent 96959ec3d7
commit 459cee5315
5 changed files with 50 additions and 12 deletions

View File

@@ -12,9 +12,12 @@ export function parseTimeoutMs(raw: unknown): number | undefined {
if (!trimmed) {
return undefined;
}
value = Number.parseInt(trimmed, 10);
if (!/^\d+$/u.test(trimmed)) {
return undefined;
}
value = Number(trimmed);
}
return Number.isFinite(value) ? value : undefined;
return Number.isSafeInteger(value) && value > 0 ? value : undefined;
}
function invalidTimeout(value?: string): Error {
@@ -53,8 +56,11 @@ export function parseTimeoutMsWithFallback(
return fallbackMs;
}
const parsed = Number.parseInt(value, 10);
if (!Number.isFinite(parsed) || parsed <= 0) {
if (!/^\d+$/u.test(value)) {
throw invalidTimeout(value);
}
const parsed = Number(value);
if (!Number.isSafeInteger(parsed) || parsed <= 0) {
throw invalidTimeout(value);
}
return parsed;