modification de méthode vérification de l'adresse IP
This commit is contained in:
@@ -1,37 +1,51 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Déterminer l'interface réseau active
|
# Fichier contenant les réservations DHCP (modifier si nécessaire)
|
||||||
INTERFACE=$(ip route | grep default | awk '{print $5}')
|
RESERVATION_FILE="/etc/dnsmasq.d/custom_hosts"
|
||||||
if [[ -z "$INTERFACE" ]]; then
|
|
||||||
echo "Erreur : Impossible de détecter une interface réseau active."
|
# Plage d'adresses IP à analyser (exemple : 192.168.1.100-192.168.1.200)
|
||||||
|
IP_RANGE_START="192.168.1.100"
|
||||||
|
IP_RANGE_END="192.168.1.200"
|
||||||
|
|
||||||
|
# Fonction pour convertir une IP en un entier pour la comparaison
|
||||||
|
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
|
||||||
|
|
||||||
# Obtenir l'adresse IP et le masque de sous-réseau
|
# Lire toutes les IP utilisées dans le fichier de réservation
|
||||||
IP_ADDR=$(ip -4 addr show "$INTERFACE" | grep -oP '(?<=inet\s)\d+(\.\d+){3}')
|
USED_IPS=($(grep -oE 'address=/[^/]+/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+' "$RESERVATION_FILE" | awk -F'/' '{print $3}'))
|
||||||
SUBNET_MASK=$(ip -4 addr show "$INTERFACE" | grep -oP '(?<=inet\s)\d+(\.\d+){3}/\d+' | cut -d'/' -f2)
|
|
||||||
|
|
||||||
# Vérifier que l'adresse et le masque sont valides
|
# Convertir les IP utilisées en entiers pour faciliter la recherche
|
||||||
if [[ -z "$IP_ADDR" || -z "$SUBNET_MASK" ]]; then
|
declare -A USED_IP_MAP
|
||||||
echo "Erreur : Impossible de récupérer l'adresse IP et le masque de sous-réseau."
|
for ip in "${USED_IPS[@]}"; do
|
||||||
exit 1
|
USED_IP_MAP[$(ip_to_int "$ip")]=1
|
||||||
fi
|
done
|
||||||
|
|
||||||
# Calculer l'adresse réseau
|
# Trouver la première IP disponible
|
||||||
IFS='.' read -r i1 i2 i3 i4 <<< "$(echo "$IP_ADDR" | cut -d'/' -f1)"
|
START_INT=$(ip_to_int "$IP_RANGE_START")
|
||||||
NET_PREFIX=$(sipcalc "$IP_ADDR/$SUBNET_MASK" | grep 'Network address' | awk '{print $3}')
|
END_INT=$(ip_to_int "$IP_RANGE_END")
|
||||||
|
|
||||||
# Scanner le réseau et trouver la première adresse libre
|
for (( ip=START_INT; ip<=END_INT; ip++ )); do
|
||||||
echo "🔍 Scan du réseau $NET_PREFIX/$SUBNET_MASK en cours..."
|
if [[ -z "${USED_IP_MAP[$ip]}" ]]; then
|
||||||
for ((i=2; i<255; i++)); do
|
FREE_IP=$(int_to_ip "$ip")
|
||||||
TEST_IP="$i1.$i2.$i3.$i"
|
echo "✅ Première IP disponible : $FREE_IP"
|
||||||
|
|
||||||
# Vérifier si l'IP répond au ping
|
|
||||||
if ! ping -c 1 -W 1 "$TEST_IP" &>/dev/null; then
|
|
||||||
echo "✅ Première IP disponible : $TEST_IP"
|
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
echo "❌ Aucune IP libre trouvée dans le sous-réseau."
|
echo "❌ Aucune IP libre trouvée dans la plage définie."
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
Reference in New Issue
Block a user