Compare commits
2 Commits
569ec5457e
...
0f6cdc7fcc
Author | SHA1 | Date |
---|---|---|
|
0f6cdc7fcc | |
|
6b997e9446 |
scripts/server-dhcp
|
@ -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
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Reference in New Issue