amélioration de l'interacetion et de la proposition de recherhe
This commit is contained in:
@@ -1,103 +1,83 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# Basé sur un travail de Cédric Abonnel / Cédrix sous licence CC BY-NC 4.0
|
# Basé sur un travail de Cédric Abonnel / Cédrix sous licence CC BY-NC 4.0
|
||||||
|
|
||||||
# Importer les fonctions communes
|
# Déterminer l'interface réseau active (exclure loopback)
|
||||||
source "$(dirname "$0")/../common/common_utils.sh"
|
INTERFACE=$(ip route | awk '/default/ {print $5; exit}')
|
||||||
|
|
||||||
# Vérifier si le script est exécuté en root
|
# Vérifier si une interface est détectée
|
||||||
check_root
|
if [[ -z "$INTERFACE" ]]; then
|
||||||
|
echo "❌ Aucune interface réseau active détectée."
|
||||||
# Vérifie si une IP est fournie
|
|
||||||
if [ -z "$1" ]; then
|
|
||||||
echo "Usage: $0 <IP>"
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
IP="$1"
|
# Déterminer l'adresse IP et le masque réseau de l'interface active
|
||||||
|
IP_INFO=$(ip -4 addr show "$INTERFACE" | awk '/inet / {print $2}')
|
||||||
|
NETWORK_IP=$(echo "$IP_INFO" | cut -d'/' -f1)
|
||||||
|
NETMASK_CIDR=$(echo "$IP_INFO" | cut -d'/' -f2)
|
||||||
|
|
||||||
echo "🔍 Recherche du nom d'hôte pour l'IP : $IP"
|
# Extraire le préfixe réseau (ex: "192.168.100")
|
||||||
|
PREFIX=$(echo "$NETWORK_IP" | awk -F. '{print $1"."$2"."$3}')
|
||||||
|
|
||||||
# Fonction pour vérifier si une commande est disponible
|
# Calculer la plage IP en fonction du masque
|
||||||
command_exists() {
|
TOTAL_HOSTS=$(( 2 ** (32 - NETMASK_CIDR) ))
|
||||||
command -v "$1" &> /dev/null
|
IP_RANGE_START="$PREFIX.1"
|
||||||
|
IP_RANGE_END="$PREFIX.$(( TOTAL_HOSTS - 2 ))" # -2 pour exclure le broadcast et l'adresse réseau
|
||||||
|
|
||||||
|
# Afficher la plage détectée
|
||||||
|
echo "🔍 Plage IP détectée :"
|
||||||
|
echo " ➡ Début : $IP_RANGE_START"
|
||||||
|
echo " ➡ Fin : $IP_RANGE_END"
|
||||||
|
|
||||||
|
# Demander confirmation ou modification de la plage
|
||||||
|
read -p "Nouvelle adresse de début (laisser vide pour conserver $IP_RANGE_START) : " NEW_START
|
||||||
|
read -p "Nouvelle adresse de fin (laisser vide pour conserver $IP_RANGE_END) : " NEW_END
|
||||||
|
|
||||||
|
# Si l'utilisateur ne saisit rien, conserver les valeurs détectées
|
||||||
|
IP_RANGE_START=${NEW_START:-$IP_RANGE_START}
|
||||||
|
IP_RANGE_END=${NEW_END:-$IP_RANGE_END}
|
||||||
|
|
||||||
|
# Fichier contenant les réservations DHCP
|
||||||
|
RESERVATION_FILE="/etc/dnsmasq.d/custom_hosts"
|
||||||
|
|
||||||
|
# Fonction pour convertir une IP en un entier
|
||||||
|
ip_to_int() {
|
||||||
|
local IFS=.
|
||||||
|
local ip=($1)
|
||||||
|
echo $(( (ip[0] << 24) + (ip[1] << 16) + (ip[2] << 8) + ip[3] ))
|
||||||
}
|
}
|
||||||
|
|
||||||
# Détection du serveur DNS en prenant en compte dnsmasq et fallback sur resolv.conf
|
# Fonction pour convertir un entier en IP
|
||||||
get_dns_server() {
|
int_to_ip() {
|
||||||
local dns_server=""
|
local ip=$1
|
||||||
|
echo "$(( (ip >> 24) & 255 )).$(( (ip >> 16) & 255 )).$(( (ip >> 8) & 255 )).$(( ip & 255 ))"
|
||||||
if command_exists resolvectl; then
|
|
||||||
dns_server=$(resolvectl dns | awk '/^Global:/ {print $2; exit}')
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$dns_server" ] && command_exists dnsmasq; then
|
|
||||||
dns_server=$(ss -tulpn | grep dnsmasq | awk '{print $5}' | cut -d: -f1 | head -n1)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$dns_server" ] && [ -f /etc/resolv.conf ]; then
|
|
||||||
dns_server=$(grep -m1 '^nameserver' /etc/resolv.conf | awk '{print $2}')
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "${dns_server:-9.9.9.9}" # Utilisation d'un fallback 9.9.9.9 si aucun DNS trouvé
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DNS_SERVER=$(get_dns_server)
|
# Vérifier si le fichier des réservations existe
|
||||||
echo "🛜 Serveur DNS détecté : $DNS_SERVER"
|
if [[ ! -f "$RESERVATION_FILE" ]]; then
|
||||||
|
echo "Erreur : Le fichier des réservations $RESERVATION_FILE n'existe pas."
|
||||||
# 1️⃣ Test LLMNR (Link-Local Multicast Name Resolution)
|
exit 1
|
||||||
if command_exists resolvectl; then
|
|
||||||
HOSTNAME_LLMNR=$(resolvectl query "$IP" 2>/dev/null | grep -oP '(?<=Name:\s).*' | head -n1)
|
|
||||||
if [ -n "$HOSTNAME_LLMNR" ]; then
|
|
||||||
echo "✅ LLMNR: $HOSTNAME_LLMNR"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "⚠ LLMNR non disponible (resolvectl absent)"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 2️⃣ Test mDNS (Multicast DNS / Avahi)
|
# Lire toutes les IP utilisées dans le fichier de réservation
|
||||||
if command_exists avahi-resolve; then
|
USED_IPS=($(grep -oE 'address=/[^/]+/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+' "$RESERVATION_FILE" | awk -F'/' '{print $3}'))
|
||||||
HOSTNAME_MDNS=$(avahi-resolve -a "$IP" 2>/dev/null | awk '{print $2}')
|
|
||||||
if [ -n "$HOSTNAME_MDNS" ]; then
|
# Vérification et recherche de la première IP disponible
|
||||||
echo "✅ mDNS (Avahi): $HOSTNAME_MDNS"
|
START_INT=$(ip_to_int "$IP_RANGE_START")
|
||||||
|
END_INT=$(ip_to_int "$IP_RANGE_END")
|
||||||
|
|
||||||
|
CURRENT_IP_INT=$START_INT
|
||||||
|
|
||||||
|
while (( CURRENT_IP_INT <= END_INT )); do
|
||||||
|
CURRENT_IP=$(int_to_ip "$CURRENT_IP_INT")
|
||||||
|
|
||||||
|
# Vérifier si l'IP est déjà réservée
|
||||||
|
if [[ ! " ${USED_IPS[@]} " =~ " $CURRENT_IP " ]]; then
|
||||||
|
echo "✅ Première IP disponible : $CURRENT_IP"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
else
|
|
||||||
echo "⚠ mDNS non disponible (avahi-resolve absent)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# 3️⃣ Vérification du cache ARP
|
(( CURRENT_IP_INT++ ))
|
||||||
if command_exists arp; then
|
done
|
||||||
HOSTNAME_ARP=$(arp -a | grep "$IP" | awk '{print $1}')
|
|
||||||
if [ -n "$HOSTNAME_ARP" ]; then
|
|
||||||
echo "✅ ARP: $HOSTNAME_ARP"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "⚠ ARP non disponible"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# 4️⃣ Vérification via NetBIOS (Windows/Samba)
|
echo "❌ Plus aucune IP disponible dans la plage définie."
|
||||||
if command_exists nmblookup; then
|
|
||||||
HOSTNAME_NETBIOS=$(nmblookup -A "$IP" 2>/dev/null | grep -m1 '<00>' | awk '{print $1}')
|
|
||||||
if [ -n "$HOSTNAME_NETBIOS" ]; then
|
|
||||||
echo "✅ NetBIOS: $HOSTNAME_NETBIOS"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "⚠ NetBIOS non disponible (nmblookup absent)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# 5️⃣ Scan réseau avec Nmap pour identifier l'hôte
|
|
||||||
if command_exists nmap; then
|
|
||||||
HOSTNAME_NMAP=$(nmap --dns-servers "$DNS_SERVER" -sP "$IP" 2>/dev/null | grep "Nmap scan report" | awk '{print $5}')
|
|
||||||
if [ -n "$HOSTNAME_NMAP" ]; then
|
|
||||||
echo "✅ Nmap: $HOSTNAME_NMAP"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "⚠ Nmap non disponible"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "❌ Aucune correspondance trouvée."
|
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
Reference in New Issue
Block a user