amélioration de la découverte du nom de domaine. amelioration de l'efficacité de la recherche du domaine
This commit is contained in:
@@ -18,11 +18,23 @@ 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 les bornes de la plage d'adresses IP en fonction du masque
|
||||
NETMASK=$(( 32 - NETMASK_CIDR ))
|
||||
TOTAL_HOSTS=$(( 2 ** NETMASK ))
|
||||
# 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
|
||||
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"
|
||||
@@ -49,33 +61,23 @@ fi
|
||||
# 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}'))
|
||||
|
||||
# Si aucune IP n'est réservée, retourner la première adresse 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
|
||||
# Vérification et recherche de la première IP disponible
|
||||
START_INT=$(ip_to_int "$IP_RANGE_START")
|
||||
END_INT=$(ip_to_int "$IP_RANGE_END")
|
||||
|
||||
if (( NEXT_IP_INT > END_INT )); then
|
||||
echo "❌ Plus aucune IP disponible dans la plage définie."
|
||||
exit 1
|
||||
fi
|
||||
CURRENT_IP_INT=$START_INT
|
||||
|
||||
echo "✅ Première IP disponible : $NEXT_IP"
|
||||
exit 0
|
||||
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
|
||||
fi
|
||||
|
||||
(( CURRENT_IP_INT++ ))
|
||||
done
|
||||
|
||||
echo "❌ Plus aucune IP disponible dans la plage définie."
|
||||
exit 1
|
||||
|
||||
Reference in New Issue
Block a user