amélioration de la découverte du nom de domaine. amelioration de l'efficacité de la recherche du domaine
This commit is contained in:
parent
680b9a2af9
commit
579631df00
scripts/server-dhcp
|
@ -1,83 +1,63 @@
|
||||||
#!/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
|
||||||
|
|
||||||
# Déterminer l'interface réseau active (exclure loopback)
|
# Fichier contenant les enregistrements
|
||||||
INTERFACE=$(ip route | awk '/default/ {print $5; exit}')
|
FILE="/etc/dnsmasq.d/custom_hosts"
|
||||||
|
|
||||||
# Vérifier si une interface est détectée
|
# Vérification de l'existence du fichier
|
||||||
if [[ -z "$INTERFACE" ]]; then
|
if [[ ! -f "$FILE" ]]; then
|
||||||
echo "❌ Aucune interface réseau active détectée."
|
echo "Erreur: Le fichier $FILE n'existe pas."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Déterminer l'adresse IP et le masque réseau de l'interface active
|
# Vérification des arguments
|
||||||
IP_INFO=$(ip -4 addr show "$INTERFACE" | awk '/inet / {print $2}')
|
if [[ $# -ne 1 ]]; then
|
||||||
NETWORK_IP=$(echo "$IP_INFO" | cut -d'/' -f1)
|
echo "Usage: $0 <nom_machine|FQDN|adresse_IP>"
|
||||||
NETMASK_CIDR=$(echo "$IP_INFO" | cut -d'/' -f2)
|
|
||||||
|
|
||||||
# Extraire le préfixe réseau (ex: "192.168.100")
|
|
||||||
PREFIX=$(echo "$NETWORK_IP" | awk -F. '{print $1"."$2"."$3}')
|
|
||||||
|
|
||||||
# Calculer la plage IP en fonction du masque
|
|
||||||
TOTAL_HOSTS=$(( 2 ** (32 - NETMASK_CIDR) ))
|
|
||||||
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] ))
|
|
||||||
}
|
|
||||||
|
|
||||||
# Fonction pour convertir un entier en IP
|
|
||||||
int_to_ip() {
|
|
||||||
local ip=$1
|
|
||||||
echo "$(( (ip >> 24) & 255 )).$(( (ip >> 16) & 255 )).$(( (ip >> 8) & 255 )).$(( ip & 255 ))"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Vérifier si le fichier des réservations existe
|
|
||||||
if [[ ! -f "$RESERVATION_FILE" ]]; then
|
|
||||||
echo "Erreur : Le fichier des réservations $RESERVATION_FILE n'existe pas."
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Lire toutes les IP utilisées dans le fichier de réservation
|
SEARCH_TERM="$1"
|
||||||
USED_IPS=($(grep -oE 'address=/[^/]+/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+' "$RESERVATION_FILE" | awk -F'/' '{print $3}'))
|
|
||||||
|
|
||||||
# Vérification et recherche de la première IP disponible
|
# Détection du nom de domaine
|
||||||
START_INT=$(ip_to_int "$IP_RANGE_START")
|
if [[ -f /etc/resolv.conf ]]; then
|
||||||
END_INT=$(ip_to_int "$IP_RANGE_END")
|
DOMAIN=$(awk '/^search / {print $2; exit} /^domain / {print $2; exit}' /etc/resolv.conf)
|
||||||
|
fi
|
||||||
|
|
||||||
CURRENT_IP_INT=$START_INT
|
# Alternative si resolv.conf n'existe pas ou est vide
|
||||||
|
if [[ -z "$DOMAIN" ]]; then
|
||||||
while (( CURRENT_IP_INT <= END_INT )); do
|
DOMAIN=$(hostname --domain 2>/dev/null) # Essayer avec hostname
|
||||||
CURRENT_IP=$(int_to_ip "$CURRENT_IP_INT")
|
if [[ -z "$DOMAIN" ]]; then
|
||||||
|
DOMAIN=$(nmcli -t -f IP4.DOMAIN dev show | head -n 1) # Essayer avec nmcli
|
||||||
# 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
|
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
(( CURRENT_IP_INT++ ))
|
# Vérifier qu'on a bien trouvé un domaine
|
||||||
done
|
if [[ -z "$DOMAIN" ]]; then
|
||||||
|
echo "Erreur: Impossible de détecter le nom de domaine."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Si l'entrée ne contient pas un point, on ajoute le domaine détecté
|
||||||
|
if [[ ! "$SEARCH_TERM" =~ \. ]]; then
|
||||||
|
SEARCH_TERM="$SEARCH_TERM.$DOMAIN"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Vérification si l'entrée est une adresse IP
|
||||||
|
if [[ "$SEARCH_TERM" =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
|
||||||
|
RESULTS=$(grep -E "/$SEARCH_TERM\$" "$FILE")
|
||||||
|
else
|
||||||
|
if [[ ! "$SEARCH_TERM" =~ ^[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$ ]]; then
|
||||||
|
echo "Erreur: '$SEARCH_TERM' ne semble pas être un FQDN valide."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
RESULTS=$(grep -E "^address=/$SEARCH_TERM/" "$FILE")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Vérification et affichage des résultats
|
||||||
|
if [[ -n "$RESULTS" ]]; then
|
||||||
|
echo "Résultats trouvés :"
|
||||||
|
echo "$RESULTS"
|
||||||
|
else
|
||||||
|
echo "Aucun résultat trouvé pour '$SEARCH_TERM'."
|
||||||
|
fi
|
||||||
|
|
||||||
echo "❌ Plus aucune IP disponible dans la plage définie."
|
|
||||||
exit 1
|
|
||||||
|
|
|
@ -18,11 +18,23 @@ NETMASK_CIDR=$(echo "$IP_INFO" | cut -d'/' -f2)
|
||||||
# Extraire le préfixe réseau (ex: "192.168.100")
|
# Extraire le préfixe réseau (ex: "192.168.100")
|
||||||
PREFIX=$(echo "$NETWORK_IP" | awk -F. '{print $1"."$2"."$3}')
|
PREFIX=$(echo "$NETWORK_IP" | awk -F. '{print $1"."$2"."$3}')
|
||||||
|
|
||||||
# Calculer les bornes de la plage d'adresses IP en fonction du masque
|
# Calculer la plage IP en fonction du masque
|
||||||
NETMASK=$(( 32 - NETMASK_CIDR ))
|
TOTAL_HOSTS=$(( 2 ** (32 - NETMASK_CIDR) ))
|
||||||
TOTAL_HOSTS=$(( 2 ** NETMASK ))
|
|
||||||
IP_RANGE_START="$PREFIX.1"
|
IP_RANGE_START="$PREFIX.1"
|
||||||
IP_RANGE_END="$PREFIX.$(( TOTAL_HOSTS - 2 ))" # -2 pour exclure le broadcast
|
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
|
# Fichier contenant les réservations DHCP
|
||||||
RESERVATION_FILE="/etc/dnsmasq.d/custom_hosts"
|
RESERVATION_FILE="/etc/dnsmasq.d/custom_hosts"
|
||||||
|
@ -49,33 +61,23 @@ fi
|
||||||
# Lire toutes les IP utilisées dans le fichier de réservation
|
# Lire toutes les IP utilisées dans le fichier de réservation
|
||||||
USED_IPS=($(grep -oE 'address=/[^/]+/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+' "$RESERVATION_FILE" | awk -F'/' '{print $3}'))
|
USED_IPS=($(grep -oE 'address=/[^/]+/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+' "$RESERVATION_FILE" | awk -F'/' '{print $3}'))
|
||||||
|
|
||||||
# Si aucune IP n'est réservée, retourner la première adresse disponible
|
# Vérification et recherche de la première IP disponible
|
||||||
if [[ ${#USED_IPS[@]} -eq 0 ]]; then
|
|
||||||
echo "✅ Première IP disponible : $IP_RANGE_START"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Trouver la plus grande IP utilisée
|
|
||||||
MAX_IP_INT=0
|
|
||||||
for ip in "${USED_IPS[@]}"; do
|
|
||||||
ip_int=$(ip_to_int "$ip")
|
|
||||||
if (( ip_int > MAX_IP_INT )); then
|
|
||||||
MAX_IP_INT=$ip_int
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Calculer la prochaine IP disponible
|
|
||||||
NEXT_IP_INT=$((MAX_IP_INT + 1))
|
|
||||||
NEXT_IP=$(int_to_ip "$NEXT_IP_INT")
|
|
||||||
|
|
||||||
# Vérifier que cette IP est bien dans la plage autorisée
|
|
||||||
START_INT=$(ip_to_int "$IP_RANGE_START")
|
START_INT=$(ip_to_int "$IP_RANGE_START")
|
||||||
END_INT=$(ip_to_int "$IP_RANGE_END")
|
END_INT=$(ip_to_int "$IP_RANGE_END")
|
||||||
|
|
||||||
if (( NEXT_IP_INT > END_INT )); then
|
CURRENT_IP_INT=$START_INT
|
||||||
echo "❌ Plus aucune IP disponible dans la plage définie."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "✅ Première IP disponible : $NEXT_IP"
|
while (( CURRENT_IP_INT <= END_INT )); do
|
||||||
exit 0
|
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
|
||||||
|
fi
|
||||||
|
|
||||||
|
(( CURRENT_IP_INT++ ))
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "❌ Plus aucune IP disponible dans la plage définie."
|
||||||
|
exit 1
|
||||||
|
|
Loading…
Reference in New Issue