<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki.sachsen.schule/dwiki/index.php?action=history&amp;feed=atom&amp;title=Benutzer%3AKirmse%2Fdelixs-pooladd</id>
	<title>Benutzer:Kirmse/delixs-pooladd - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.sachsen.schule/dwiki/index.php?action=history&amp;feed=atom&amp;title=Benutzer%3AKirmse%2Fdelixs-pooladd"/>
	<link rel="alternate" type="text/html" href="https://wiki.sachsen.schule/dwiki/index.php?title=Benutzer:Kirmse/delixs-pooladd&amp;action=history"/>
	<updated>2026-05-06T06:28:06Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Delixs</subtitle>
	<generator>MediaWiki 1.44.0</generator>
	<entry>
		<id>https://wiki.sachsen.schule/dwiki/index.php?title=Benutzer:Kirmse/delixs-pooladd&amp;diff=7241&amp;oldid=prev</id>
		<title>Kirmse: Script zum Eintragen von Pools (Räumen) in den LDAP</title>
		<link rel="alternate" type="text/html" href="https://wiki.sachsen.schule/dwiki/index.php?title=Benutzer:Kirmse/delixs-pooladd&amp;diff=7241&amp;oldid=prev"/>
		<updated>2009-06-17T17:48:20Z</updated>

		<summary type="html">&lt;p&gt;Script zum Eintragen von Pools (Räumen) in den LDAP&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== delixs-pooladd ==&lt;br /&gt;
&lt;br /&gt;
* Dieses Script dient dazu, im LDAP Pools einzutragen&lt;br /&gt;
&lt;br /&gt;
* Parameter: --pool oder -p, --tnetz oder -t, --nummer oder -n, --range oder -r  &lt;br /&gt;
&lt;br /&gt;
* Aufruf: delixs-pooladd -p mathe -t 10.101.0.0 -n 4 -r 50:150&lt;br /&gt;
&lt;br /&gt;
das Teilnetz muss normalerweise nicht angegeben werden. Voreinstellung ist &amp;#039;10.100.0.0&amp;#039;. Dieser Parameter ist nur dazu da, damit dieses Script (später) auch dann genutzt werden kann, wenn weitere echte Netzwerkkarten eingebaut wurden.&lt;br /&gt;
&lt;br /&gt;
Der Parameter --nummer gibt die &amp;quot;Poolnummer&amp;quot; an. Auch dieser sollte nicht angegeben werden, weil das Script die vorhandenen Pools ermittelt und die größte Poolnummer herauszieht. Diese wird normalerweise um 1 erhöht und als Poolnummer genommen.&lt;br /&gt;
&lt;br /&gt;
Auch der Poolbereich sollte normalerweise nicht angegeben werden. Es wird als Voreinstellung 100:200 genommen.&lt;br /&gt;
&lt;br /&gt;
Für dieses Beispiel würde als dhcpRange 10.101.4.50 10.101.4.150 eingetragen.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== das Script ====&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;perl&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
#!/usr/bin/perl&lt;br /&gt;
use warnings; &lt;br /&gt;
use strict;&lt;br /&gt;
&lt;br /&gt;
use Net::LDAP;&lt;br /&gt;
use Getopt::Long;&lt;br /&gt;
&lt;br /&gt;
my ($ldap, $ldap_base, $pass, $entry, $mesg, $poolname, $range, $poolnumber, &lt;br /&gt;
    $teilnetz, $tn, $vorgabe_teilnetz, $vorgabe_range, $vorgabe_nummer,&lt;br /&gt;
    $min, $max, @numbers, $temp, @temp, $anzahl, $rangemin, $rangemax);&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
#--------- Konfigurationsbereich --------------------------------------------&lt;br /&gt;
&lt;br /&gt;
$vorgabe_teilnetz = &amp;#039;10.100.0.0&amp;#039;;  # Vorgabe fuer das Teilnetz&lt;br /&gt;
$vorgabe_range    = &amp;#039;100:200&amp;#039;;      # Vorgabe fuer den Poolbereich &lt;br /&gt;
$vorgabe_nummer   = 1;              # Vorgabe fuer den ersten Pool&lt;br /&gt;
&lt;br /&gt;
#----------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Initialisieren der Variablen fuer die Parameter&lt;br /&gt;
$poolname   = &amp;#039;&amp;#039;;&lt;br /&gt;
$teilnetz   = &amp;#039;&amp;#039;;&lt;br /&gt;
$poolnumber = &amp;#039;&amp;#039;;&lt;br /&gt;
$range      = &amp;#039;&amp;#039;;&lt;br /&gt;
&lt;br /&gt;
# wir holen uns zuerst die Parameter,&lt;br /&gt;
# falls --help, dann Ausgabe der Hilfe (siehe &amp;amp;help) und beenden&lt;br /&gt;
GetOptions(&amp;#039;pool=s&amp;#039;   =&amp;gt; \$poolname,&lt;br /&gt;
           &amp;#039;tnetz=s&amp;#039;  =&amp;gt; \$teilnetz,&lt;br /&gt;
           &amp;#039;nummer=i&amp;#039; =&amp;gt; \$poolnumber,&lt;br /&gt;
           &amp;#039;range=s&amp;#039;  =&amp;gt; \$range,       # z.B. 100:200  &lt;br /&gt;
           &amp;#039;help&amp;#039;     =&amp;gt; \&amp;amp;help);&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
#--------- formale Ueberpruefung der uebergebenen Parameter -----------------&lt;br /&gt;
&lt;br /&gt;
# Wenn kein Parameter -p oder --poolname uebergeben wurde, dann Abbruch&lt;br /&gt;
if ($poolname eq &amp;#039;&amp;#039;) {&lt;br /&gt;
  die &amp;quot;Abbruch: es wurde kein Name fuer die Rechnergruppe uebergeben!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# Wenn der Poolname nicht den (meinen) Konventionen entspricht, dann Abbruch&lt;br /&gt;
unless ($poolname =~ /^[a-zA-Z]\w{1,10}$/) {&lt;br /&gt;
  die &amp;quot;Abbruch: Der Name fuer die Rechnergruppe ist nicht korrekt!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# Wenn Parameter Teilnetz uebergeben, dann kontrollieren&lt;br /&gt;
unless ($teilnetz eq &amp;#039;&amp;#039;) {&lt;br /&gt;
  # ob richtiges Format &lt;br /&gt;
  unless ($teilnetz =~ /^\d{1,3}\.\d{1,3}\.\d{1,3}\.0$/) {&lt;br /&gt;
    die &amp;quot;Abbruch: Das Teilnetz $teilnetz ist keine gueltige Angabe!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
# Wenn der Parameter nicht uebergeben&lt;br /&gt;
else {&lt;br /&gt;
  # dann setzen wir das Teilnetz&lt;br /&gt;
  $teilnetz = $vorgabe_teilnetz;  &lt;br /&gt;
}  &lt;br /&gt;
&lt;br /&gt;
# wenn Parameter Poolnummer uebergeben, dann kontrollieren&lt;br /&gt;
unless ($poolnumber eq &amp;#039;&amp;#039;) {&lt;br /&gt;
  # ob richtiges Format (eine max. 3stellige Zahl)&lt;br /&gt;
  unless ($poolnumber =~ /^\d{1,3}$/) {&lt;br /&gt;
    die &amp;quot;Abbruch: Die Poolnummer $poolnumber ist keine gueltige Angabe!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
  # Test, ob Wert groesser 0&lt;br /&gt;
  unless ($poolnumber &amp;gt; 0) {&lt;br /&gt;
    die &amp;quot;Abbruch: Poolnumber muss groesser 0 sein!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
  # Test, ob Wert kleiner 255 &lt;br /&gt;
  unless ($poolnumber &amp;lt; 255) {&lt;br /&gt;
    die &amp;quot;Abbruch: Poolnumber muss kleiner 255 sein!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# Wenn Parameter $range uebergeben, dann kontrollieren, &lt;br /&gt;
unless ($range eq &amp;#039;&amp;#039;) {&lt;br /&gt;
  # ob richtiges Format (zwei max. dreistellige Zahlen)&lt;br /&gt;
  unless ($range =~ /^\d{1,3}:\d{1,3}$/) {&lt;br /&gt;
    die &amp;quot;Abbruch: Der DHCP-Range ist nicht im richtigen Format angegeben!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
  &lt;br /&gt;
  # wir zerlegen die Eingabe&lt;br /&gt;
  ($min,$max) = split /:/, $range;&lt;br /&gt;
&lt;br /&gt;
  # Test, ob beide Werte groesser 0 &lt;br /&gt;
  unless ($min &amp;gt; 0 and $max &amp;gt; 0) {&lt;br /&gt;
    die &amp;quot;Abbruch: Beide Werte muessen groesser 0 sein!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
  # Test, ob beide Werte kleiner 255 &lt;br /&gt;
  unless ($min &amp;lt; 255 and $max &amp;lt; 255) {&lt;br /&gt;
    die &amp;quot;Abbruch: Beide Werte muessen kleiner 255 sein!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
  # Test, ob der kleinere Wert zuerst steht &lt;br /&gt;
  unless ($min &amp;lt; $max) {&lt;br /&gt;
    die &amp;quot;Abbruch: der erste Wert muss kleiner als der zweite sein!\n&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
# Wenn kein Parameter uebergeben&lt;br /&gt;
else {&lt;br /&gt;
  # dann setzen wir den Bereich&lt;br /&gt;
  $range = &amp;#039;100:200&amp;#039;;  &lt;br /&gt;
}  &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
#----------- Arbeiten mit Dateien (ldap.conf, ldap.secret) -----------------&lt;br /&gt;
&lt;br /&gt;
# Wenn wir keine root-Rechte haben, dann Abbruch&lt;br /&gt;
if ($&amp;gt; != 0) { # siehe $EFFECTIVE_USER_ID,$EUID&lt;br /&gt;
  die &amp;quot;Abbruch: das Script muss mit root-Rechten ausgefuehrt werden!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# wir holen uns die Such-Basis ($ldap_base) aus der ldap.conf&lt;br /&gt;
open DATEI, &amp;#039;&amp;lt;&amp;#039;, &amp;#039;/etc/ldap/ldap.conf&amp;#039; &lt;br /&gt;
  or die &amp;quot;Abbruch: konnte ldap.conf nicht oeffnen, $!\n&amp;quot;;&lt;br /&gt;
while (my $zeile = &amp;lt;DATEI&amp;gt;) {&lt;br /&gt;
  if ($zeile =~ m/^\s*base\s+(\w.*\w)\s*$/i) {&lt;br /&gt;
    $ldap_base = $1;&lt;br /&gt;
    last;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
close DATEI;&lt;br /&gt;
&lt;br /&gt;
# da wir (spaeter) in den LDAP schreiben wollen, brauchen wir noch das Passwort&lt;br /&gt;
open DATEI, &amp;#039;&amp;lt;&amp;#039;, &amp;#039;/etc/ldap.secret&amp;#039; &lt;br /&gt;
  or die &amp;quot;Abbruch: konnte ldap.secret nicht oeffnen, $!\n&amp;quot;;&lt;br /&gt;
$pass = &amp;lt;DATEI&amp;gt;;&lt;br /&gt;
chomp($pass);&lt;br /&gt;
close DATEI;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# ------------- Ueberpruefungen im LDAP --------------------------------------&lt;br /&gt;
&lt;br /&gt;
# wir verbinden uns mit dem LDAP&lt;br /&gt;
$ldap = Net::LDAP-&amp;gt;new(&amp;#039;127.0.0.1&amp;#039;, version =&amp;gt; 3) or die &amp;quot;Abbruch: $@&amp;quot;;&lt;br /&gt;
$ldap-&amp;gt;bind( dn =&amp;gt; &amp;quot;cn=admin, $ldap_base&amp;quot;, password =&amp;gt; $pass)&lt;br /&gt;
  or die &amp;quot;Abbruch: konnte mich nicht mit dem LDAP verbinden&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
# wir ueberpruefen, ob das Teilnetz im LDAP existiert &lt;br /&gt;
$mesg = $ldap-&amp;gt;search(base   =&amp;gt; &amp;quot;cn=$teilnetz,cn=DHCP Config,$ldap_base&amp;quot;,&lt;br /&gt;
                      filter =&amp;gt; &amp;quot;cn=$teilnetz&amp;quot;,&lt;br /&gt;
                      attrs  =&amp;gt; &amp;#039;dhcpNetMask&amp;#039; );&lt;br /&gt;
$mesg-&amp;gt;code and die $mesg-&amp;gt;error;&lt;br /&gt;
# wenn wir keinen Eintrag erhalten haben, dann Abbruch&lt;br /&gt;
if (scalar ($mesg-&amp;gt;entries) == 0) {&lt;br /&gt;
  die &amp;quot;Abbruch: Das Teilnetz $teilnetz existiert nicht im LDAP!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# Wir ueberpruefen, ob der Poolname schon verwendet wird&lt;br /&gt;
# es wird ganz bewusst diese Suchbasis verwendet, um alle Teilnetze zu erfassen&lt;br /&gt;
$mesg = $ldap-&amp;gt;search(&lt;br /&gt;
          base   =&amp;gt; &amp;quot;cn=DHCP Config,$ldap_base&amp;quot;, &lt;br /&gt;
          filter =&amp;gt; &amp;quot;cn=$poolname&amp;quot; );&lt;br /&gt;
# wenn Fehlercode, dann das Script mit Fehlermeldung sterben lassen&lt;br /&gt;
$mesg-&amp;gt;code and die $mesg-&amp;gt;error;&lt;br /&gt;
# Wenn der DN gefunden wird  dann Abbruch&lt;br /&gt;
if (scalar ($mesg-&amp;gt;entries) &amp;gt; 0) {&lt;br /&gt;
  die &amp;quot;Abbruch: Der Poolname $poolname wird schon verwendet!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# wir holen uns von dem Teilnetz von allen Pools die dhcpRanges&lt;br /&gt;
$mesg = $ldap-&amp;gt;search(&lt;br /&gt;
          base   =&amp;gt; &amp;quot;cn=$teilnetz,cn=DHCP Config,$ldap_base&amp;quot;, &lt;br /&gt;
          filter =&amp;gt; &amp;#039;objectClass=dhcpPool&amp;#039;,&lt;br /&gt;
          attrs  =&amp;gt; &amp;#039;dhcpRange&amp;#039; );&lt;br /&gt;
# wenn Fehlercode, dann das Script mit Fehlermeldung sterben lassen&lt;br /&gt;
$mesg-&amp;gt;code and die $mesg-&amp;gt;error;&lt;br /&gt;
&lt;br /&gt;
# dann holen wir uns von allen dhcpRange-Eintraegen den Min-Wert&lt;br /&gt;
@numbers = ();&lt;br /&gt;
if (scalar $mesg-&amp;gt;entries &amp;gt; 0) {&lt;br /&gt;
  foreach my $entry ($mesg-&amp;gt;entries) {&lt;br /&gt;
    $temp = $entry-&amp;gt;get_value(&amp;#039;dhcpRange&amp;#039;);&lt;br /&gt;
    @temp = split /\s+/, $temp;              # am Leerzeichen trennen&lt;br /&gt;
    if ($temp[0] =~ /^\d{1,3}\.\d{1,3}\.(\d{1,3})\.\d{1,3}$/) {&lt;br /&gt;
      push @numbers, $1; &lt;br /&gt;
    } &lt;br /&gt;
  }               &lt;br /&gt;
} &lt;br /&gt;
&lt;br /&gt;
# wenn keine Poolnummer angegeben wurde, dann &lt;br /&gt;
if ($poolnumber eq &amp;#039;&amp;#039;) {&lt;br /&gt;
  # dann sortieren wir die Liste, groesste Zahl ist vorn  &lt;br /&gt;
  @numbers = sort { $b &amp;lt;=&amp;gt; $a } @numbers;&lt;br /&gt;
  if (scalar @numbers == 0) {&lt;br /&gt;
    $poolnumber = 1;&lt;br /&gt;
  }&lt;br /&gt;
  else {&lt;br /&gt;
    $poolnumber = $numbers[0] + 1;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
else {&lt;br /&gt;
  # dann sollte diese Poolnummer nicht in der Liste sein&lt;br /&gt;
  $anzahl = grep /^$poolnumber$/, @numbers;&lt;br /&gt;
  if ( $anzahl &amp;gt; 0) {&lt;br /&gt;
    die &amp;quot;Abbruch: Poolnummer $poolnumber wird schon verwendet!\n&amp;quot;; &lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# ------------- Der Eintrag in den LDAP --------------------------------------&lt;br /&gt;
&lt;br /&gt;
# wir zerlegen $range und holen die ersten beiden Oktetts vom Teilnetz&lt;br /&gt;
($min,$max) = split /:/, $range;&lt;br /&gt;
($tn) = $teilnetz =~ /^(\d{1,3}\.\d{1,3})\.\d{1,3}\.\d{1,3}$/;&lt;br /&gt;
&lt;br /&gt;
# wir basten uns die beiden Werte fuer dhcpRange&lt;br /&gt;
$rangemin = join(&amp;#039;.&amp;#039;, $tn, $poolnumber, $min);&lt;br /&gt;
$rangemax = join(&amp;#039;.&amp;#039;, $tn, $poolnumber, $max);&lt;br /&gt;
&lt;br /&gt;
# jetzt tragen wir (endlich) den Pool ein&lt;br /&gt;
$mesg = $ldap-&amp;gt;add(&lt;br /&gt;
          dn   =&amp;gt; &amp;quot;cn=$poolname,cn=$teilnetz,cn=DHCP Config,$ldap_base&amp;quot;,&lt;br /&gt;
          attr =&amp;gt; [ objectClass =&amp;gt; [&amp;#039;top&amp;#039;, &amp;#039;dhcpPool&amp;#039;],&lt;br /&gt;
                    cn          =&amp;gt; $poolname,&lt;br /&gt;
                    dhcpRange   =&amp;gt; &amp;quot;$rangemin $rangemax&amp;quot; ] ); &lt;br /&gt;
# wenn Fehlercode, dann das Script mit Fehlermeldung sterben lassen&lt;br /&gt;
$mesg-&amp;gt;code and die $mesg-&amp;gt;error;&lt;br /&gt;
&lt;br /&gt;
# wir trennen uns vom LDAP&lt;br /&gt;
$ldap-&amp;gt;unbind;&lt;br /&gt;
&lt;br /&gt;
# Ausgabe auf der Konsole (Rueckmeldung)&lt;br /&gt;
print &amp;quot;Die Rechnergruppe \&amp;quot;$poolname\&amp;quot; wurde in den LDAP eingetragen.\n&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
################### Programm-Ende #####################################&lt;br /&gt;
&lt;br /&gt;
# Wenn Parameter -h uebergeben wurde, dann Hilfe ausgegeben und beenden&lt;br /&gt;
sub help&lt;br /&gt;
{&lt;br /&gt;
   print &amp;quot;Hilfe muss noch erstellt werden.\n&amp;quot;;&lt;br /&gt;
   exit (0);&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
__END__&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Kirmse</name></author>
	</entry>
</feed>