Compare commits
3 Commits
97531efe3d
...
569ec5457e
Author | SHA1 | Date |
---|---|---|
|
569ec5457e | |
|
2bd7121f6e | |
|
765057a367 |
scripts/server-dhcp
|
@ -0,0 +1,39 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Importer les fonctions communes
|
||||||
|
source "$(dirname "$0")/../common/common_utils.sh"
|
||||||
|
|
||||||
|
# Vérifier si le script est exécuté en root
|
||||||
|
check_root
|
||||||
|
|
||||||
|
# Fichier de configuration de dnsmasq
|
||||||
|
DNSMASQ_CONF="/etc/dnsmasq.d/custom_hosts"
|
||||||
|
|
||||||
|
# Vérifier que dnsmasq est installé
|
||||||
|
if ! command -v dnsmasq &> /dev/null; then
|
||||||
|
echo "dnsmasq n'est pas installé. Installez-le avec : sudo ./setup_dhcp.sh"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Vérifier les arguments
|
||||||
|
if [[ $# -ne 2 ]]; then
|
||||||
|
echo "Usage: $0 <IP> <HOSTNAME>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
IP="$1"
|
||||||
|
HOSTNAME="$2"
|
||||||
|
|
||||||
|
# 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
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Ajouter l'entrée dans le fichier de configuration
|
||||||
|
echo "address=/$HOSTNAME/$IP" >> "$DNSMASQ_CONF"
|
||||||
|
|
||||||
|
# Redémarrer dnsmasq pour appliquer les changements
|
||||||
|
systemctl restart dnsmasq
|
||||||
|
|
||||||
|
echo "Ajout réussi : $HOSTNAME -> $IP"
|
|
@ -0,0 +1,37 @@
|
||||||
|
#!/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."
|
||||||
|
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)
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# 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}')
|
||||||
|
|
||||||
|
# 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"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "❌ Aucune IP libre trouvée dans le sous-réseau."
|
||||||
|
exit 1
|
|
@ -106,6 +106,7 @@ expand-hosts
|
||||||
domain-needed
|
domain-needed
|
||||||
no-negcache
|
no-negcache
|
||||||
bogus-priv
|
bogus-priv
|
||||||
|
filterwin2k
|
||||||
no-resolv
|
no-resolv
|
||||||
server=9.9.9.9
|
server=9.9.9.9
|
||||||
server=149.112.112.112
|
server=149.112.112.112
|
||||||
|
@ -128,8 +129,6 @@ dhcp-option=15,$DOMAINE
|
||||||
dhcp-option=23,64
|
dhcp-option=23,64
|
||||||
# Taille MTU
|
# Taille MTU
|
||||||
dhcp-option=26,1500
|
dhcp-option=26,1500
|
||||||
# Serveur NTP
|
|
||||||
dhcp-option=42,fr.pool.ntp.org
|
|
||||||
# Désactiver NetBIOS sur Windows
|
# Désactiver NetBIOS sur Windows
|
||||||
dhcp-option=43,01:04:00:00:00:02
|
dhcp-option=43,01:04:00:00:00:02
|
||||||
# Suffixe DNS
|
# Suffixe DNS
|
||||||
|
|
Loading…
Reference in New Issue