Merge in DNS/adguard-home from ADG-9415 to master Squashed commit of the following: commit76bf99499aMerge:29529970a0389515eeAuthor: Ildar Kamalov <ik@adguard.com> Date: Wed Feb 26 18:31:41 2025 +0300 Merge branch 'master' into ADG-9415 commit29529970a3Merge:b49790daf782a1a982Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Mon Feb 24 15:44:38 2025 +0300 Merge branch 'master' into ADG-9415 commitb49790daf8Author: Ildar Kamalov <ik@adguard.com> Date: Mon Feb 24 15:30:18 2025 +0300 fix default lease duration value commitcb307472ecAuthor: Ildar Kamalov <ik@adguard.com> Date: Mon Feb 24 10:35:26 2025 +0300 fix default response status commit115e743e1aAuthor: Ildar Kamalov <ik@adguard.com> Date: Mon Feb 24 10:32:46 2025 +0300 fix upstream description commit26b0eddacaAuthor: Ildar Kamalov <ik@adguard.com> Date: Tue Feb 18 17:40:41 2025 +0300 use const for test config file commit58faa7c537Author: Ildar Kamalov <ik@adguard.com> Date: Tue Feb 18 17:31:04 2025 +0300 fix install config commit0a3346d911Author: Ildar Kamalov <ik@adguard.com> Date: Mon Feb 17 15:25:23 2025 +0300 fix install check config commit17c4c26ea8Author: Ildar Kamalov <ik@adguard.com> Date: Fri Feb 14 17:18:20 2025 +0300 fix query log commit14a2685ae3Author: Ildar Kamalov <ik@adguard.com> Date: Fri Feb 14 15:52:36 2025 +0300 fix dhcp initial values commite7a8db7afdAuthor: Ildar Kamalov <ik@adguard.com> Date: Fri Feb 14 14:37:24 2025 +0300 fix encryption form values commit1c8917f7acAuthor: Ildar Kamalov <ik@adguard.com> Date: Fri Feb 14 14:07:29 2025 +0300 fix blocked services submit commit4dfa536ceaAuthor: Ildar Kamalov <ik@adguard.com> Date: Fri Feb 14 13:50:47 2025 +0300 dns config ip validation commit4fee83fe13Author: Ildar Kamalov <ik@adguard.com> Date: Wed Feb 12 17:49:54 2025 +0300 add playwright warning commit8c2f36e7a6Author: Ildar Kamalov <ik@adguard.com> Date: Tue Feb 11 18:36:18 2025 +0300 fix config file name commit83db5f33dcAuthor: Ildar Kamalov <ik@adguard.com> Date: Tue Feb 11 16:16:43 2025 +0300 temp config file commit9080c1620fAuthor: Ildar Kamalov <ik@adguard.com> Date: Tue Feb 11 15:01:46 2025 +0300 update readme commitee1520307fMerge:fd12e33c02fe2d254bAuthor: Ildar Kamalov <ik@adguard.com> Date: Tue Feb 11 14:44:06 2025 +0300 Merge branch 'master' into ADG-9415 commitfd12e33c06Author: Igor Lobanov <bniwredyc@gmail.com> Date: Mon Feb 10 10:29:43 2025 +0100 added typecheck on build, fixed eslint commitb3849eebc4Merge:225167a8b9bf3ee128Author: Igor Lobanov <bniwredyc@gmail.com> Date: Mon Feb 10 09:43:32 2025 +0100 Merge branch 'ADG-9415' of https://bit.int.agrd.dev/scm/dns/adguard-home into ADG-9415 ... and 94 more commits
66 lines
2.2 KiB
TypeScript
66 lines
2.2 KiB
TypeScript
import { networkInterfaces } from 'os';
|
|
import type { NetworkInterfaceInfo } from 'node:os';
|
|
|
|
interface DHCPConfig {
|
|
interfaceName: string;
|
|
rangeStart: string;
|
|
rangeEnd: string;
|
|
subnetMask: string;
|
|
}
|
|
|
|
const DEFAULT_SUBNET_MASK = '255.255.255.0';
|
|
const DEFAULT_SUBNET_MASK_OCTETS = DEFAULT_SUBNET_MASK.split('.').map(Number);
|
|
|
|
function checkIsIPv4(addr: NetworkInterfaceInfo): boolean {
|
|
return addr.family === 'IPv4' && !addr.internal;
|
|
}
|
|
|
|
function calculateNetwork(ip: number[], mask: number[]): number[] {
|
|
// Calculate the network address by applying the bitwise AND operation.
|
|
// eslint-disable-next-line no-bitwise
|
|
return ip.map((octet, i) => octet & mask[i]);
|
|
}
|
|
|
|
function calculateBroadcast(network: number[], mask: number[]): number[] {
|
|
// Calculate the broadcast address by ORing the network address with the inverted mask.
|
|
// eslint-disable-next-line no-bitwise
|
|
return network.map((octet, i) => octet | (~mask[i] & 255));
|
|
}
|
|
|
|
export function getDHCPConfig(): DHCPConfig {
|
|
const interfaces = networkInterfaces();
|
|
|
|
// Select the first interface that has a valid non-internal IPv4 address.
|
|
const ipV4Interface = Object.entries(interfaces)
|
|
.map(([name, addresses]) => ({ name, addresses }))
|
|
.find((i) => i.addresses?.some(checkIsIPv4));
|
|
|
|
if (!ipV4Interface) {
|
|
throw new Error('No suitable network interface found');
|
|
}
|
|
|
|
// Get the first valid IPv4 address from the interface.
|
|
const ipv4Address = ipV4Interface.addresses.find(checkIsIPv4);
|
|
|
|
const ip = ipv4Address.address.split('.').map(Number);
|
|
const mask = ipv4Address.netmask?.split('.').map(Number) || DEFAULT_SUBNET_MASK_OCTETS;
|
|
|
|
const network = calculateNetwork(ip, mask);
|
|
|
|
// Calculate first usable address (network address + 1)
|
|
const rangeStart = [...network];
|
|
rangeStart[3] = network[3] + 1;
|
|
|
|
// Calculate broadcast address and then the last usable address (broadcast - 1)
|
|
const broadcast = calculateBroadcast(network, mask);
|
|
const rangeEnd = [...broadcast];
|
|
rangeEnd[3] = broadcast[3] - 1;
|
|
|
|
return {
|
|
interfaceName: ipV4Interface.name,
|
|
rangeStart: rangeStart.join('.'),
|
|
rangeEnd: rangeEnd.join('.'),
|
|
subnetMask: ipv4Address.netmask || DEFAULT_SUBNET_MASK,
|
|
};
|
|
}
|