<?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-hostdel</id>
	<title>Benutzer:Kirmse/delixs-hostdel - 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-hostdel"/>
	<link rel="alternate" type="text/html" href="https://wiki.sachsen.schule/dwiki/index.php?title=Benutzer:Kirmse/delixs-hostdel&amp;action=history"/>
	<updated>2026-05-02T16:46:58Z</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-hostdel&amp;diff=7250&amp;oldid=prev</id>
		<title>Kirmse: Script zum Löschen von Hosts im LDAP</title>
		<link rel="alternate" type="text/html" href="https://wiki.sachsen.schule/dwiki/index.php?title=Benutzer:Kirmse/delixs-hostdel&amp;diff=7250&amp;oldid=prev"/>
		<updated>2009-06-18T20:08:46Z</updated>

		<summary type="html">&lt;p&gt;Script zum Löschen von Hosts im LDAP&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== delixs-hostdel ==&lt;br /&gt;
&lt;br /&gt;
* Dieses Script dient dazu, Hosts im LDAP zu löschen&lt;br /&gt;
&lt;br /&gt;
* Parameter: --help oder -h, --pool oder -p, --tnetz oder -t, --rechner oder -r  &lt;br /&gt;
&lt;br /&gt;
* Aufruf: delixs-hostdel -p mathe -r Aachen&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;
&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, $teilnetz, $vorgabe_teilnetz, &lt;br /&gt;
    $poolname, $pcname);&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;
&lt;br /&gt;
#----------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Initialisieren der Variablen fuer die Parameter&lt;br /&gt;
$pcname     = &amp;#039;&amp;#039;;&lt;br /&gt;
$poolname   = &amp;#039;&amp;#039;;&lt;br /&gt;
$teilnetz   = &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;rechner=s&amp;#039; =&amp;gt; \$pcname,&lt;br /&gt;
           &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;help&amp;#039;      =&amp;gt; \&amp;amp;help);&lt;br /&gt;
&lt;br /&gt;
# Wenn kein Parameter -r oder --rechner uebergeben wurde, dann Abbruch&lt;br /&gt;
if ($pcname eq &amp;#039;&amp;#039;) {&lt;br /&gt;
  die &amp;quot;Abbruch: es wurde kein Name fuer den Rechner uebergeben!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# Wenn der Rechnername nicht den (meinen) Konventionen entspricht, dann Abbruch&lt;br /&gt;
unless ($pcname =~ /^[a-zA-Z]\w{1,10}$/) {&lt;br /&gt;
  die &amp;quot;Abbruch: Der Name $pcname fuer den Rechner ist nicht korrekt!\n&amp;quot;;&lt;br /&gt;
}&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 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;
# 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; );  # nur ein Dummy&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 Pool im LDAP existiert &lt;br /&gt;
$mesg = $ldap-&amp;gt;search(base   =&amp;gt; &amp;quot;cn=$poolname,cn=$teilnetz,cn=DHCP Config,$ldap_base&amp;quot;,&lt;br /&gt;
                      filter =&amp;gt; &amp;quot;cn=$poolname&amp;quot;);&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: Der angegebene Pool $poolname existiert nicht im LDAP!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# wir ueberpruefen, ob der Host im LDAP existiert &lt;br /&gt;
$mesg = $ldap-&amp;gt;search(&lt;br /&gt;
          base   =&amp;gt; &amp;quot;cn=$pcname,cn=$poolname,cn=$teilnetz,cn=DHCP Config,$ldap_base&amp;quot;, &lt;br /&gt;
          filter =&amp;gt; &amp;#039;objectClass=dhcpHost&amp;#039; );&lt;br /&gt;
# Wenn der Host nicht gefunden wird, dann Abbruch&lt;br /&gt;
if (scalar ($mesg-&amp;gt;entries) == 0) {&lt;br /&gt;
  die &amp;quot;Abbruch: Der Host $pcname existiert nicht im LDAP!\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
# nun loeschen wir den Host&lt;br /&gt;
$mesg = $ldap-&amp;gt;delete(&amp;quot;cn=$pcname,cn=$poolname,cn=$teilnetz,cn=DHCP Config,$ldap_base&amp;quot;);&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;Der DHCP-Host \&amp;quot;$pcname\&amp;quot; wurde geloescht.\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;
__END__&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Kirmse</name></author>
	</entry>
</feed>