Compare commits

...

2 Commits

2 changed files with 69 additions and 37 deletions

View File

@ -16,24 +16,42 @@ if ! command -v dnsmasq &> /dev/null; then
fi fi
# Vérifier les arguments # Vérifier les arguments
if [[ $# -ne 2 ]]; then if [[ $# -lt 2 ]]; then
echo "Usage: $0 <IP> <HOSTNAME>" echo "Usage: $0 <IP> <HOSTNAME1> [HOSTNAME2] [HOSTNAME3] ..."
exit 1 exit 1
fi fi
IP="$1" IP="$1"
HOSTNAME="$2" shift # Supprime le premier argument pour ne garder que les hostnames
HOSTNAMES=("$@")
# Vérifier si l'entrée existe déjà # Variable pour suivre si un changement a été fait
if grep -qE "^address=/$HOSTNAME/$IP$" "$DNSMASQ_CONF"; then MODIFIED=0
echo "L'association $HOSTNAME -> $IP existe déjà dans $DNSMASQ_CONF."
exit 0 # Vérifier si l'IP existe déjà dans le fichier
EXISTING_HOSTNAMES=($(grep "address=.*/$IP" "$DNSMASQ_CONF" | sed -E "s/address=\/(.*)\/$IP/\1/"))
if [[ ${#EXISTING_HOSTNAMES[@]} -gt 0 ]]; then
echo "L'adresse IP $IP existe déjà avec les noms suivants : ${EXISTING_HOSTNAMES[*]}"
else
echo "Nouvelle adresse IP détectée : $IP"
fi fi
# Ajouter l'entrée dans le fichier de configuration # Vérifier et ajouter chaque hostname
for HOSTNAME in "${HOSTNAMES[@]}"; do
if [[ ! " ${EXISTING_HOSTNAMES[*]} " =~ " ${HOSTNAME} " ]]; then
echo "address=/$HOSTNAME/$IP" >> "$DNSMASQ_CONF" echo "address=/$HOSTNAME/$IP" >> "$DNSMASQ_CONF"
echo "Ajout de : $HOSTNAME -> $IP"
MODIFIED=1
else
echo "L'association $HOSTNAME -> $IP existe déjà."
fi
done
# Redémarrer dnsmasq pour appliquer les changements # Redémarrer dnsmasq seulement si des changements ont été faits
if [[ $MODIFIED -eq 1 ]]; then
systemctl restart dnsmasq systemctl restart dnsmasq
echo "Redémarrage de dnsmasq effectué."
echo "Ajout réussi : $HOSTNAME -> $IP" else
echo "Aucune modification nécessaire."
fi

View File

@ -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