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
# Vérifier les arguments
if [[ $# -ne 2 ]]; then
echo "Usage: $0 <IP> <HOSTNAME>"
if [[ $# -lt 2 ]]; then
echo "Usage: $0 <IP> <HOSTNAME1> [HOSTNAME2] [HOSTNAME3] ..."
exit 1
fi
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à
if grep -qE "^address=/$HOSTNAME/$IP$" "$DNSMASQ_CONF"; then
echo "L'association $HOSTNAME -> $IP existe déjà dans $DNSMASQ_CONF."
exit 0
# Variable pour suivre si un changement a été fait
MODIFIED=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
# Ajouter l'entrée dans le fichier de configuration
echo "address=/$HOSTNAME/$IP" >> "$DNSMASQ_CONF"
# Vérifier et ajouter chaque hostname
for HOSTNAME in "${HOSTNAMES[@]}"; do
if [[ ! " ${EXISTING_HOSTNAMES[*]} " =~ " ${HOSTNAME} " ]]; then
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
systemctl restart dnsmasq
echo "Ajout réussi : $HOSTNAME -> $IP"
# Redémarrer dnsmasq seulement si des changements ont été faits
if [[ $MODIFIED -eq 1 ]]; then
systemctl restart dnsmasq
echo "Redémarrage de dnsmasq effectué."
else
echo "Aucune modification nécessaire."
fi

View File

@ -1,37 +1,51 @@
#!/bin/bash
# Déterminer l'interface réseau active
INTERFACE=$(ip route | grep default | awk '{print $5}')
if [[ -z "$INTERFACE" ]]; then
echo "Erreur : Impossible de détecter une interface réseau active."
# Fichier contenant les réservations DHCP (modifier si nécessaire)
RESERVATION_FILE="/etc/dnsmasq.d/custom_hosts"
# 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
fi
# Obtenir l'adresse IP et le masque de sous-réseau
IP_ADDR=$(ip -4 addr show "$INTERFACE" | grep -oP '(?<=inet\s)\d+(\.\d+){3}')
SUBNET_MASK=$(ip -4 addr show "$INTERFACE" | grep -oP '(?<=inet\s)\d+(\.\d+){3}/\d+' | cut -d'/' -f2)
# 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}'))
# Vérifier que l'adresse et le masque sont valides
if [[ -z "$IP_ADDR" || -z "$SUBNET_MASK" ]]; then
echo "Erreur : Impossible de récupérer l'adresse IP et le masque de sous-réseau."
exit 1
fi
# Convertir les IP utilisées en entiers pour faciliter la recherche
declare -A USED_IP_MAP
for ip in "${USED_IPS[@]}"; do
USED_IP_MAP[$(ip_to_int "$ip")]=1
done
# Calculer l'adresse réseau
IFS='.' read -r i1 i2 i3 i4 <<< "$(echo "$IP_ADDR" | cut -d'/' -f1)"
NET_PREFIX=$(sipcalc "$IP_ADDR/$SUBNET_MASK" | grep 'Network address' | awk '{print $3}')
# Trouver la première IP disponible
START_INT=$(ip_to_int "$IP_RANGE_START")
END_INT=$(ip_to_int "$IP_RANGE_END")
# Scanner le réseau et trouver la première adresse libre
echo "🔍 Scan du réseau $NET_PREFIX/$SUBNET_MASK en cours..."
for ((i=2; i<255; i++)); do
TEST_IP="$i1.$i2.$i3.$i"
# 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"
for (( ip=START_INT; ip<=END_INT; ip++ )); do
if [[ -z "${USED_IP_MAP[$ip]}" ]]; then
FREE_IP=$(int_to_ip "$ip")
echo "✅ Première IP disponible : $FREE_IP"
exit 0
fi
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