@aikidosec/firewall
Version:
Zen by Aikido is an embedded Application Firewall that autonomously protects Node.js apps against common and critical attacks, provides rate limiting, detects malicious traffic (including bots), and more.
29 lines (28 loc) • 1.05 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.findHostnameInUserInput = findHostnameInUserInput;
const getPortFromURL_1 = require("../../helpers/getPortFromURL");
const tryParseURL_1 = require("../../helpers/tryParseURL");
function findHostnameInUserInput(userInput, hostname, port) {
if (userInput.length <= 1) {
return false;
}
const hostnameURL = (0, tryParseURL_1.tryParseURL)(`http://${hostname}`);
if (!hostnameURL) {
return false;
}
const variants = [userInput, `http://${userInput}`, `https://${userInput}`];
for (const variant of variants) {
const userInputURL = (0, tryParseURL_1.tryParseURL)(variant);
if (userInputURL && userInputURL.hostname === hostnameURL.hostname) {
const userPort = (0, getPortFromURL_1.getPortFromURL)(userInputURL);
if (!port) {
return true;
}
if (port && userPort === port) {
return true;
}
}
}
return false;
}
;