Benutzer:Kirmse/delixs-userdel
delixs-userdel
- Dieses Script dient dazu, User oder ganze Klassen zu löschen
- Parameter: --help oder -h, --user oder -u, --class oder -c
- Aufruf: delixs-userdel -u mmustermann
oder
- Aufruf: delixs-userdel -c 8c
das Script
<source lang="perl">
- !/usr/bin/perl
use warnings; use strict;
use Net::LDAP; use Getopt::Long;
- dieses Script loescht einen User oder eine ganze Klasse
my ($ldap, $ldap_base, $pass, $mesg, $entry, $user, $class,
@users, $klasse, $nscd_status, @ausgabe);
- Initialisieren der Variablen fuer die Parameter
$user = ; $class = ;
- wir holen uns zuerst die Parameter,
- falls --help, dann Ausgabe der Hilfe (siehe &help) und beenden
GetOptions('user=s' => \$user,
'class=s' => \$class,
'help' => \&help);
- Wenn weder --user noch --class uebergeben, dann Abbruch
if ($user eq and $class eq ) {
die "Abbruch: es wurden nicht uebergeben, wer geloescht werden soll!\n";
}
- Wenn --user und --class uebergeben, dann auch Abbruch
if ($user ne and $class ne ) {
die "Abbruch: es kann entweder nur --user oder --class uebergeben werden!\n";
}
- Wenn wir keine root-Rechte haben, dann Abbruch
if ($> != 0) { # siehe $EFFECTIVE_USER_ID,$EUID
die "Abbruch: das Script muss mit root-Rechten ausgefuehrt werden!\n";
}
- wir holen uns die Such-Basis ($ldap_base) aus der ldap.conf
open DATEI, '<', '/etc/ldap/ldap.conf'
or die "Abbruch: konnte ldap.conf nicht oeffnen, $!\n";
while (my $zeile = <DATEI>) {
if ($zeile =~ m/^\s*base\s+(\w.*\w)\s*$/i) {
$ldap_base = $1;
last;
}
} close DATEI;
- da wir (spaeter) in den LDAP schreiben wollen, brauchen wir noch das Passwort
open DATEI, '<', '/etc/ldap.secret'
or die "Abbruch: konnte ldap.secret nicht oeffnen, $!\n";
$pass = <DATEI>; chomp($pass); close DATEI;
- wir verbinden uns mit dem LDAP
$ldap = Net::LDAP->new('127.0.0.1', version => 3) or die "Abbruch: $@"; $ldap->bind( dn => "cn=admin, $ldap_base", password => $pass)
or die "Abbruch: konnte mich nicht mit dem LDAP verbinden";
- das Loeschen
- Wenn der User uebergeben wurde
if ($user ne ) {
&user_delete($user);
}
- wenn eine Klasse geloescht werden soll
else {
# wir suchen alle Schueler der Klasse
$mesg = $ldap->search(base => "ou=people,ou=accounts,$ldap_base",
filter => 'gidNumber=1002',
attrs => ['uid', 'gecos'],
callback => \&user_liste );
if (scalar @users == 0) {
push @ausgabe, "Achtung: Es wurde kein Schueler in Klasse $class gefunden -> nichts geloescht.\n"
}
# fuer jeden dieser Schueler
foreach my $schueler (@users) {
&user_delete($schueler);
}
}
- wir trennen uns vom LDAP
$ldap->unbind;
- Ausgabe auf der Konsole (Liste ausgeben)
foreach my $element (@ausgabe) {
print $element;
}
- wir aktualisieren den NSCD (Nameserver Cache Daemon)
$nscd_status = system "/etc/init.d/nscd status >/dev/null 2>&1"; if ($nscd_status == 0) {
system "/etc/init.d/nscd restart > /dev/null 2>&1";
}
exit(0);
- Programm-Ende #####################################
- die Routine zum User loeschen
sub user_delete {
my $user = shift;
# holen wir uns den DN und das Homeverzeichnis
my $dn = ;
my $home = ;
my $message = $ldap->search(base => "uid=$user,ou=people,ou=accounts,$ldap_base",
filter => "uid=$user",
attrs => 'homeDirectory');
# da Login eindeutig, haben wir nur einen Treffer
my $entry = ($message->entries)[0];
if (defined($entry)) {
$dn = $entry->dn;
$home = $entry->get_value('homeDirectory');
# jetzt loeschen wir im LDAP
$message = $ldap->delete($dn);
# jetzt loeschen wir das Homeverzeichnis
system('rm', '-rf', $home);
# Rueckmeldung in eine globale Liste, um Logfile und Konsole zu bedienen
push @ausgabe, "User $user geloescht.\n"
}
else {
# Rueckmeldung in eine globale Liste, um Logfile und Konsole zu bedienen
push @ausgabe, "Achtung: User $user wurde nicht gefunden -> nicht geloescht.\n"
}
}
- Callback-Routine: wir suchen Eintraege mit der Klasse
sub user_liste {
my ($mesg, $entry) = @_;
if (defined($entry)) {
my ($name, $klasse) = split /,/ , $entry->get_value('gecos');
if ($klasse eq $class) {
push @users, $entry->get_value('uid'); # das login wird gepusht
}
}
}
- Wenn Parameter -h uebergeben wurde, dann Hilfe ausgegeben und beenden
sub help {
print "Hilfe muss noch erstellt werden.\n"; exit (0);
}
__END__
</source>