guardia-messenger/node_modules/freeport-async/index.js
DESKTOP-TKLFCPRython f29f525c77 refactor: 101.79.17.164 → zioinfo.co.kr 전체 도메인 변환 + Manager UI 배포
- 37개 파일 IP → zioinfo.co.kr 치환 (소스/매뉴얼/설정/하네스)
- Manager DrConsole/NetworkConsole/CsapConsole 빌드 + /var/www/manager/ 배포
- 테스트: Manager HTTP 200, ITSM 신규 API 7개 전체 200

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 10:09:17 +09:00

65 lines
1.7 KiB
JavaScript

const net = require("net");
const DEFAULT_PORT_RANGE_START = 11000;
function testPortAsync(port, hostname) {
return new Promise(function(fulfill, reject) {
var server = net.createServer();
server.listen({ port: port, host: hostname }, function(err) {
server.once("close", function() {
setTimeout(() => fulfill(true), 0);
});
server.close();
});
server.on("error", function(err) {
setTimeout(() => fulfill(false), 0);
});
});
}
async function availableAsync(port, options = {}) {
const hostnames =
options.hostnames && options.hostnames.length ? options.hostnames : [null];
for (const hostname of hostnames) {
if (!(await testPortAsync(port, hostname))) {
return false;
}
}
return true;
}
function freePortRangeAsync(rangeSize, rangeStart, options = {}) {
rangeSize = rangeSize || 1;
return new Promise((fulfill, reject) => {
var lowPort = rangeStart || DEFAULT_PORT_RANGE_START;
var awaitables = [];
for (var i = 0; i < rangeSize; i++) {
awaitables.push(availableAsync(lowPort + i, options));
}
return Promise.all(awaitables).then(function(results) {
var ports = [];
for (var i = 0; i < results.length; i++) {
if (!results[i]) {
return freePortRangeAsync(
rangeSize,
lowPort + rangeSize,
options
).then(fulfill, reject);
}
ports.push(lowPort + i);
}
fulfill(ports);
});
});
}
async function freePortAsync(rangeStart, options = {}) {
const result = await freePortRangeAsync(1, rangeStart, options);
return result[0];
}
module.exports = freePortAsync;
module.exports.availableAsync = availableAsync;
module.exports.rangeAsync = freePortRangeAsync;