From patchwork Fri Nov 17 14:44:22 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Sebastien GISLAIN X-Patchwork-Id: 7348 Return-Path: Received: from mail01.ipfire.org (mail01.haj.ipfire.org [172.28.1.202]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (secp384r1) server-digest SHA384 client-signature ECDSA (secp384r1) client-digest SHA384) (Client CN "mail01.haj.ipfire.org", Issuer "R3" (verified OK)) by web04.haj.ipfire.org (Postfix) with ESMTPS id 4SX06S0ckMz3wvt for ; Fri, 17 Nov 2023 14:44:32 +0000 (UTC) Received: from mail02.haj.ipfire.org (mail02.haj.ipfire.org [172.28.1.201]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (secp384r1) server-digest SHA384 client-signature ECDSA (secp384r1) client-digest SHA384) (Client CN "mail02.haj.ipfire.org", Issuer "R3" (verified OK)) by mail01.ipfire.org (Postfix) with ESMTPS id 4SX06Q1YwtzmP; Fri, 17 Nov 2023 14:44:30 +0000 (UTC) Received: from mail02.haj.ipfire.org (localhost [127.0.0.1]) by mail02.haj.ipfire.org (Postfix) with ESMTP id 4SX06P5v97z33hH; Fri, 17 Nov 2023 14:44:29 +0000 (UTC) Received: from mail01.ipfire.org (mail01.haj.ipfire.org [172.28.1.202]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (secp384r1) server-digest SHA384 client-signature ECDSA (secp384r1) client-digest SHA384) (Client CN "mail01.haj.ipfire.org", Issuer "R3" (verified OK)) by mail02.haj.ipfire.org (Postfix) with ESMTPS id 4SX06M69HMz2xF9 for ; Fri, 17 Nov 2023 14:44:27 +0000 (UTC) Received: from smtp.smtpout.orange.fr (smtp-29.smtpout.orange.fr [80.12.242.29]) (using TLSv1.2 with cipher ECDHE-ECDSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "*.smtpout.orange.fr", Issuer "DigiCert Global G2 TLS RSA SHA256 2020 CA1" (verified OK)) by mail01.ipfire.org (Postfix) with ESMTPS id 4SX06L4F0fzPf for ; Fri, 17 Nov 2023 14:44:26 +0000 (UTC) Authentication-Results: mail01.ipfire.org; dkim=pass header.d=wanadoo.fr header.s=t20230301 header.b=gvQ6jJMM; dmarc=fail reason="No valid SPF, DKIM not aligned (relaxed)" header.from=free.fr (policy=none); spf=neutral (mail01.ipfire.org: 80.12.242.29 is neither permitted nor denied by domain of sebastien.gislain@free.fr) smtp.mailfrom=sebastien.gislain@free.fr ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=lists.ipfire.org; s=202003rsa; t=1700232266; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=TIaN7v4DkyUzb0Jv9Xvt9xzhEHYPPm8mm4w+pjiZh6c=; b=nUaltbPjLmw+2UouQI6+PJDcAAhARdkVCBH1hTnvEAvVEJzdYCwWTpugI8LKL+hUr0GQ3a KhfU/ImEnREnCVtTdc94nAPErOZEUkCMGMNMwlO3xf6WhbSUJWjPNAwzXG7WPoyWFVvbOD +oP43PGQuHJ/ExezCzSta3UjOWpWlgj+JeMouUXO3dU6ZATt+QIY49cg7Z+4Kq0Ih4CbkD ZRtLjctifmhV4qdpVvRzbHsosoYUYItfDqPFvBsHxO1PYAdSq3fGYl/BQsbXIKGZJggmKy kbS4reehxOOPRzlq8+RYEMfMCnzq7ALEBKVHvn99UhLIZr2AIWDlRKtVpAX0/Q== ARC-Authentication-Results: i=1; mail01.ipfire.org; dkim=pass header.d=wanadoo.fr header.s=t20230301 header.b=gvQ6jJMM; dmarc=fail reason="No valid SPF, DKIM not aligned (relaxed)" header.from=free.fr (policy=none); spf=neutral (mail01.ipfire.org: 80.12.242.29 is neither permitted nor denied by domain of sebastien.gislain@free.fr) smtp.mailfrom=sebastien.gislain@free.fr ARC-Seal: i=1; s=202003rsa; d=lists.ipfire.org; t=1700232266; a=rsa-sha256; cv=none; b=q6TNQAOAkcOZioIKxJ3RBPQcEtDotWyzbDYMoY8BJGOuUQi56EDGUUjLhG8F90bOrH1vPG eXPUgmwvNKgiDFl8mYTxtF+/g5xcY1eShIiYa9c36BgOqRCbrwTBScgpFZw2y70x8wx/ps 33rluyD5JsNLHBDyry2fWOgY3tut25yOrkUcyfHWNNWeOA7gQiI/v0sIC6N/EwBPimIiPj fDpS7Jc7zOlEkA9zGyskCie0hdb4+bd5ixI82Af9dHemPIMu0dAnr9zdmQ0q7Ep9/JTiOU 2uazqCKnMiNAg+zQVeEInr4M/9/MRDLxnhBGffWOVv1b+njjOOaFtN4fqKELjQ== Received: from esx052.local ([90.16.56.107]) by smtp.orange.fr with ESMTPA id 4053rOEoeVgeS4053rcwDe; Fri, 17 Nov 2023 15:44:25 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=wanadoo.fr; s=t20230301; t=1700232265; bh=TIaN7v4DkyUzb0Jv9Xvt9xzhEHYPPm8mm4w+pjiZh6c=; h=From:To:Cc:Subject:Date:In-Reply-To:References; b=gvQ6jJMMqdNa6iHDzyJB6+H1BpI6PlBDnhvyudBhgkpviaVodRd/JWZ/0keI8Yrw3 ZP0O5jStLZ59k/MeMsTHmcdMEgzrK5ctADCFfcRMLcPq1ukjydnacP+jgqEMxuj5Fw jKe9kOnqnkQ8xsg5e5Vt/Wt+dcGUiHRDCiu4k0Kj1U9bjG+UetnSFQIzNYpP00bK0r BF4ISQ99u/q2MD6AdLEqfGfgY0VBQQcAxul0uTcb9r66DLwwj1MUwjRcWOZV9/5J86 HfKqstKJgnKjdqLo+XSsSIqX6Yy4INo/z3PlS6W3lMIVvV5BpDqjCerg9yWfNn9Kot fYPEZywqcpguw== X-ME-Helo: esx052.local X-ME-Auth: Z2lzbGFpbi5zZWJhc3RpZW5Ab3JhbmdlLmZy X-ME-Date: Fri, 17 Nov 2023 15:44:25 +0100 X-ME-IP: 90.16.56.107 From: Sebastien GISLAIN To: development@lists.ipfire.org Subject: [PATCH] dhcp.cgi: Add column with resolved hostname by IP address Date: Fri, 17 Nov 2023 15:44:22 +0100 Message-Id: <20231117144422.21685-1-sebastien.gislain@free.fr> X-Mailer: git-send-email 2.39.2 In-Reply-To: References: MIME-Version: 1.0 X-Rspamd-Queue-Id: 4SX06L4F0fzPf X-Spamd-Result: default: False [-2.39 / 11.00]; BAYES_HAM(-3.00)[99.99%]; MID_CONTAINS_FROM(1.00)[]; NEURAL_HAM(-1.00)[-1.000]; R_MISSING_CHARSET(0.50)[]; R_DKIM_ALLOW(-0.20)[wanadoo.fr:s=t20230301]; MIME_HTML_ONLY(0.20)[]; ONCE_RECEIVED(0.10)[]; RWL_MAILSPIKE_GOOD(-0.10)[80.12.242.29:from]; DMARC_POLICY_SOFTFAIL(0.10)[free.fr : No valid SPF, DKIM not aligned (relaxed),none]; IP_REPUTATION_SPAM(0.02)[asn: 3215(0.00), country: FR(0.01), ip: 80.12.242.29(0.00)]; MX_GOOD(-0.01)[]; RCPT_COUNT_TWO(0.00)[2]; RCVD_TLS_LAST(0.00)[]; FREEMAIL_ENVFROM(0.00)[free.fr]; ARC_NA(0.00)[]; FREEMAIL_FROM(0.00)[free.fr]; MIME_TRACE(0.00)[0:~]; TO_DN_SOME(0.00)[]; R_SPF_NEUTRAL(0.00)[?all]; FREEMAIL_CC(0.00)[free.fr]; DKIM_TRACE(0.00)[wanadoo.fr:+]; DWL_DNSWL_NONE(0.00)[wanadoo.fr:dkim]; RECEIVED_SPAMHAUS_PBL(0.00)[90.16.56.107:received]; TO_MATCH_ENVRCPT_SOME(0.00)[]; FROM_EQ_ENVFROM(0.00)[]; RCVD_IN_DNSWL_NONE(0.00)[80.12.242.29:from]; ARC_SIGNED(0.00)[lists.ipfire.org:s=202003rsa:i=1]; ASN(0.00)[asn:3215, ipnet:80.12.240.0/20, country:FR]; RCVD_VIA_SMTP_AUTH(0.00)[]; DKIM_REPUTATION(0.00)[0]; RCVD_COUNT_ONE(0.00)[1]; FROM_HAS_DN(0.00)[] X-Rspamd-Action: no action X-Rspamd-Server: mail01.haj.ipfire.org Message-ID-Hash: BJVN3YY6AOPZOTBMEZJZBQ75LHIBQ6SQ X-Message-ID-Hash: BJVN3YY6AOPZOTBMEZJZBQ75LHIBQ6SQ X-MailFrom: sebastien.gislain@free.fr X-Mailman-Rule-Misses: dmarc-mitigation; no-senders; approved; emergency; loop; banned-address; member-moderation; nonmember-moderation; administrivia; implicit-dest; max-recipients; max-size; news-moderation; no-subject; digests; suspicious-header CC: Sebastien GISLAIN X-Mailman-Version: 3.3.8 Precedence: list List-Id: IPFire development talk Archived-At: List-Archive: List-Help: List-Owner: List-Post: List-Subscribe: List-Unsubscribe: In web interface, on page DHCP Server, in table Current fixed leases, add column with resolved hostname by IP address Reviewed-by: Peter Müller --- html/cgi-bin/dhcp.cgi | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/html/cgi-bin/dhcp.cgi b/html/cgi-bin/dhcp.cgi index f45703f0b..b87da6907 100755 --- a/html/cgi-bin/dhcp.cgi +++ b/html/cgi-bin/dhcp.cgi @@ -21,6 +21,7 @@ use strict; use experimental 'smartmatch'; +use IO::Socket; # enable only the following on debugging purpose #use warnings; @@ -1007,8 +1008,9 @@ END print < - $Lang::tr{'mac address'} - $Lang::tr{'ip address'} + $Lang::tr{'mac address'} + $Lang::tr{'ip address'} + $Lang::tr{'hostname'} $Lang::tr{'remark'} next-server filename @@ -1106,9 +1108,14 @@ foreach my $line (@current2) { $TAG4 = "class='red'" if ($dhcpsettings{'KEY2'} ne $key); } + # resolved name (if exists) + my $iaddr = inet_aton($temp[1]); + my $rname = gethostbyaddr($iaddr, AF_INET); + if (!$rname || $rname eq "") { $rname = $Lang::tr{'ptr lookup failed'}; } print <$TAG2$temp[0]$TAG3 $TAG0$temp[1]$TAG1 +$rname  $temp[6]  $temp[3]  $temp[4]