| 1 |
#!/usr/bin/perl |
| 2 |
use strict; |
| 3 |
use File::Copy; |
| 4 |
|
| 5 |
# Als erstes: Sorry fuer ENGLISH/DEUTSCH Mischmasch |
| 6 |
# Zweitens: Was ist das?? |
| 7 |
# Also: |
| 8 |
# 1. Legt LDAP PosixAccounts an(Zum anmelden ueber PAM) |
| 9 |
# 2. DomainAbaehngige HOMDEDIRs |
| 10 |
# Ach schau dir den CODE an. |
| 11 |
# Kommando uebergabe (CMD/TEST(see sub GetUserDataAuto)/HTML(Webmin) |
| 12 |
|
| 13 |
my $howtotell = "HTML"; |
| 14 |
|
| 15 |
if ($howtotell eq "HTML") { |
| 16 |
use CGI; |
| 17 |
use CGI::Carp qw(fatalsToBrowser); |
| 18 |
} |
| 19 |
|
| 20 |
## ACHTUNG ### auf ALLE folgenden Parameter achten |
| 21 |
|
| 22 |
my $current_dir = "/usr/libexec/webmin/ums"; |
| 23 |
##Wenn jemand eine Funktion kennt das aktuelle Perl-Arbeitsverzeichnis zu ermitteln, bitte! |
| 24 |
my $ldap_start_uid = "999"; |
| 25 |
my $ldap_stop_uid = "20000"; |
| 26 |
# Letzters gilt auch fuer Gruppen |
| 27 |
my $mailuserpath = "/mailuser"; |
| 28 |
#Where to put your DomainDirs |
| 29 |
my $template = "/template/www"; |
| 30 |
#your Horde Template |
| 31 |
my $group_www_root = "/www"; |
| 32 |
my $mail_root = "/mail"; |
| 33 |
#your Users IMAP dir (under $HOME) |
| 34 |
my $user_www_root = "/public_html"; |
| 35 |
#your Users WWW_ROOT (under $HOME) |
| 36 |
my $base_dn = "ou=MailUser,ou=UMS,dc=europatentdienst,dc=de"; |
| 37 |
#LDAP Base DN for PosixAccounts |
| 38 |
my $horde_base_dn = "ou=Horde,ou=UMS,dc=europatentdienst,dc=de"; |
| 39 |
#LDAP Base DN for Horde |
| 40 |
my $root_dn = "'cn=Manager,dc=europatentdienst,dc=de'"; |
| 41 |
my $root_pass = "MEAS876"; |
| 42 |
# You should know what this means |
| 43 |
my $ldiffile = "/root/devel/perl/test.ldif"; |
| 44 |
my $ldif_dn_file = "/root/devel/perl/test_dn.ldif"; |
| 45 |
my $ldif_imap_file = "/root/devel/perl/test_imap.ldif"; |
| 46 |
my $ldif_horde_file = "/root/devel/perl/test_horde.ldif"; |
| 47 |
# These files are needed to generate LDIFs-->LDAPADD->LDAPServer |
| 48 |
my $virtualhost_file = "/etc/mail_test/virtusertable"; |
| 49 |
my $local_host_name_file = "/etc/mail_test/local-host-names"; |
| 50 |
my $genericstable_file = "/etc/mail_test/genericstable"; |
| 51 |
# Your Sendmail Files |
| 52 |
my $make_bin = "/usr/bin/make"; |
| 53 |
my $make_target = "/etc/mail_test"; |
| 54 |
my $remote_sendmail = "/usr/sbin/rcsendmail"; |
| 55 |
my $sendmail_command = "restart"; |
| 56 |
# I'am tiered now, sure you know what this means |
| 57 |
|
| 58 |
Main(); |
| 59 |
|
| 60 |
sub GetEnt_Passwd { |
| 61 |
my @biggest_uid; |
| 62 |
my @biggest_gid; |
| 63 |
my @existing_users; |
| 64 |
my @getent_passwd; |
| 65 |
my $foreach_counter; |
| 66 |
@getent_passwd = qx(/usr/bin/getent passwd); |
| 67 |
foreach (@getent_passwd) { |
| 68 |
@getent_passwd[$foreach_counter] =~ /(.*):x:(\d*):(\d*).*/; |
| 69 |
if ($2 > $ldap_start_uid && $2 < $ldap_stop_uid) { |
| 70 |
@existing_users[$foreach_counter] = $1; |
| 71 |
@biggest_uid[$foreach_counter] = $2; |
| 72 |
@biggest_gid[$foreach_counter] = $3; |
| 73 |
} |
| 74 |
$foreach_counter++; |
| 75 |
} |
| 76 |
|
| 77 |
@biggest_uid = sort(NummernSort @biggest_uid); |
| 78 |
@biggest_gid = sort(NummernSort @biggest_gid); |
| 79 |
@biggest_uid = reverse(@biggest_uid); |
| 80 |
@biggest_gid = reverse(@biggest_gid); |
| 81 |
my $HighestUID = @biggest_uid[0]; |
| 82 |
my $HighestGID = @biggest_gid[0]; |
| 83 |
my $UidNumber = $HighestUID + 1; |
| 84 |
my $GidNumber = $HighestGID + 1; |
| 85 |
my %HighestIDs = (HighestUID => $HighestUID,HighestGID => $HighestGID,UidNumber => $UidNumber,GidNumber => $GidNumber); |
| 86 |
return (%HighestIDs); |
| 87 |
} |
| 88 |
|
| 89 |
sub NummernSort { |
| 90 |
if ($a < $b) |
| 91 |
{return -1;} |
| 92 |
elsif($a == $b) |
| 93 |
{return 0; } |
| 94 |
else |
| 95 |
{return 1; } |
| 96 |
} |
| 97 |
|
| 98 |
sub GetUserDataCMD { |
| 99 |
my %UserDaten; |
| 100 |
print "Vorname: "; |
| 101 |
my $vorname=<STDIN>; |
| 102 |
chomp $vorname; |
| 103 |
print "Nachname: "; |
| 104 |
my $nachname=<STDIN>; |
| 105 |
chomp $nachname; |
| 106 |
print "Domain(info.de): "; |
| 107 |
my $domain=<STDIN>; |
| 108 |
chomp $domain; |
| 109 |
print "Benutzername: "; |
| 110 |
my $username=<STDIN>; |
| 111 |
chomp $username; |
| 112 |
print "Password: "; |
| 113 |
my $password=<STDIN>; |
| 114 |
chomp $password; |
| 115 |
my $imap = ""; |
| 116 |
until ($imap eq "yes" | $imap eq "no") { |
| 117 |
print "Imap/HomeDir/ModDav/User_WWW(yes/no):"; |
| 118 |
$imap=<STDIN>; |
| 119 |
chomp $imap; |
| 120 |
} |
| 121 |
print "Email(Name vor dem @):"; |
| 122 |
my $email =<STDIN>; |
| 123 |
chomp $email; |
| 124 |
$email = $email."\@".$domain; |
| 125 |
my %UserDaten = (Vorname=>$vorname,Nachname=>$nachname,Domain=>$domain,Benutzername=>$username,Password=>$password,Imap=>$imap,EMail=>$email); |
| 126 |
return (%UserDaten); |
| 127 |
} |
| 128 |
|
| 129 |
sub GetUserDataAuto { |
| 130 |
my $vorname="Test"; |
| 131 |
my $nachname="Tester"; |
| 132 |
my $domain="testing.de"; |
| 133 |
my $username="testtester"; |
| 134 |
my $password="test(/&"; |
| 135 |
my $imap="yes"; |
| 136 |
my $email= "testtester"."\@".$domain; |
| 137 |
my %UserDaten = (Vorname=>$vorname,Nachname=>$nachname,Domain=>$domain,Benutzername=>$username,Password=>$password,Imap=>$imap,EMail=>$email); |
| 138 |
return (%UserDaten); |
| 139 |
} |
| 140 |
|
| 141 |
sub CreateLDAPUser { |
| 142 |
my $cn = shift; |
| 143 |
my $user = $cn; |
| 144 |
my $domain = shift; |
| 145 |
my $pass = shift; |
| 146 |
my $surename = shift; |
| 147 |
my $givenname = shift; |
| 148 |
my $uidNumber = shift; |
| 149 |
my $gidNumber = shift; |
| 150 |
my $homeDir = shift; |
| 151 |
my $imap = shift; |
| 152 |
my $email = shift; |
| 153 |
|
| 154 |
$domain =~ /(.*)\.(.*)/; |
| 155 |
my $domain_dn = "ou=".$1."_".$2; |
| 156 |
my $domain_dir = "/".$1."_".$2; |
| 157 |
|
| 158 |
my @LDIFDATEI; |
| 159 |
@LDIFDATEI[0] = "dn: uid=$givenname $surename,$domain_dn,$base_dn\n"; |
| 160 |
@LDIFDATEI[1] = "objectclass: top\n"; |
| 161 |
@LDIFDATEI[2] = "objectclass: posixAccount\n"; |
| 162 |
@LDIFDATEI[3] = "objectclass: shadowAccount\n"; |
| 163 |
@LDIFDATEI[4] = "objectclass: account\n"; |
| 164 |
@LDIFDATEI[5] = "cn: $cn\n"; |
| 165 |
@LDIFDATEI[6] = "uid: $user\n"; |
| 166 |
@LDIFDATEI[7] = "gecos: $givenname $surename\n"; |
| 167 |
@LDIFDATEI[8] = "uidNumber: $uidNumber\n"; |
| 168 |
@LDIFDATEI[9] = "gidNumber: $gidNumber\n"; |
| 169 |
@LDIFDATEI[10] = "homeDirectory: $homeDir\n"; |
| 170 |
@LDIFDATEI[11] = "userPassword: $pass\n"; |
| 171 |
@LDIFDATEI[12] = "loginShell: /bin/false\n"; |
| 172 |
|
| 173 |
if ($imap eq "yes") { |
| 174 |
my @LDIFHORDEOU; |
| 175 |
@LDIFHORDEOU[0] = "dn: $domain_dn,$horde_base_dn\n"; |
| 176 |
@LDIFHORDEOU[1] = "ou: $domain_dn\n"; |
| 177 |
@LDIFHORDEOU[2] = "objectclass: top\n"; |
| 178 |
@LDIFHORDEOU[3] = "objectclass: organizationalUnit\n"; |
| 179 |
open(DATEI, ">$ldif_horde_file") || die "Datei nicht gefunden"; |
| 180 |
print DATEI @LDIFHORDEOU; |
| 181 |
close(DATEI); |
| 182 |
qx (/usr/bin/ldapadd -D $root_dn -x -w $root_pass -f $ldif_horde_file) |
| 183 |
} |
| 184 |
|
| 185 |
if ($imap eq "yes") { |
| 186 |
my @LDIFIMAP; |
| 187 |
@LDIFIMAP[0] = "dn: cn=$givenname $surename,$domain_dn,$horde_base_dn\n"; |
| 188 |
@LDIFIMAP[1] = "objectclass: organizationalPerson\n"; |
| 189 |
@LDIFIMAP[2] = "objectclass: inetOrgPerson\n"; |
| 190 |
@LDIFIMAP[3] = "objectclass: person\n"; |
| 191 |
@LDIFIMAP[4] = "objectclass: hordePerson\n"; |
| 192 |
@LDIFIMAP[5] = "sn: $surename\n"; |
| 193 |
@LDIFIMAP[6] = "cn: $givenname $surename\n"; |
| 194 |
@LDIFIMAP[7] = "mail: $email\n"; |
| 195 |
@LDIFIMAP[8] = "gn: $givenname\n"; |
| 196 |
open(DATEI, ">$ldif_imap_file") || die "Datei nicht gefunden"; |
| 197 |
print DATEI @LDIFIMAP; |
| 198 |
close(DATEI); |
| 199 |
qx (/usr/bin/ldapadd -D $root_dn -x -w $root_pass -f $ldif_imap_file) |
| 200 |
} |
| 201 |
|
| 202 |
|
| 203 |
if (!-e $mailuserpath.$domain_dir) { |
| 204 |
#if ($imap eq "yes") { |
| 205 |
my @LDIFOU; |
| 206 |
@LDIFOU[0] = "dn: $domain_dn,$base_dn\n"; |
| 207 |
@LDIFOU[1] = "ou: $domain_dn\n"; |
| 208 |
@LDIFOU[2] = "objectclass: top\n"; |
| 209 |
@LDIFOU[3] = "objectclass: organizationalUnit\n"; |
| 210 |
open(DATEI, ">$ldif_dn_file") || die "Datei nicht gefunden"; |
| 211 |
print DATEI @LDIFOU; |
| 212 |
close(DATEI); |
| 213 |
qx (/usr/bin/ldapadd -D $root_dn -x -w $root_pass -f $ldif_dn_file) |
| 214 |
} |
| 215 |
|
| 216 |
open(DATEI, ">$ldiffile") || die "Datei nicht gefunden"; |
| 217 |
print DATEI @LDIFDATEI; |
| 218 |
close(DATEI); |
| 219 |
|
| 220 |
qx (/usr/bin/ldapadd -D $root_dn -x -w $root_pass -f $ldiffile) |
| 221 |
} |
| 222 |
|
| 223 |
sub HomeDirGet { |
| 224 |
my $user = shift; |
| 225 |
my $domain = shift; |
| 226 |
my $imap = shift; |
| 227 |
$domain =~ /(.*)\.(.*)/; |
| 228 |
my $homedir = $mailuserpath."/".$1."_".$2."/".$user; |
| 229 |
if ($imap ne "yes") { |
| 230 |
$homedir = "/dev/null"; |
| 231 |
} |
| 232 |
return ($homedir); |
| 233 |
} |
| 234 |
|
| 235 |
sub HomeDirMake { |
| 236 |
my $user = shift; |
| 237 |
my $domain = shift; |
| 238 |
my $imap = shift; |
| 239 |
my $uid = shift; |
| 240 |
my $gid = shift; |
| 241 |
my $group = shift; |
| 242 |
$domain =~ /(.*)\.(.*)/; |
| 243 |
my $select11 = $1; |
| 244 |
my $select12 = $2; |
| 245 |
my $pre_save_path = $mailuserpath; |
| 246 |
my $domaindir = "/".$select11."_".$select12; |
| 247 |
my $homedir = $mailuserpath.$domaindir."/".$user; |
| 248 |
if ($imap eq "yes") { |
| 249 |
my $homedir = $mailuserpath.$domaindir."/".$user; |
| 250 |
if (!-e $pre_save_path.$domaindir) { |
| 251 |
mkdir ($pre_save_path.$domaindir) |
| 252 |
} |
| 253 |
if (!-e $pre_save_path.$domaindir."/".$user) { |
| 254 |
mkdir ($pre_save_path.$domaindir."/".$user) |
| 255 |
} |
| 256 |
if (!-e $pre_save_path.$domaindir."/".$user.$mail_root) { |
| 257 |
mkdir ($pre_save_path.$domaindir."/".$user.$mail_root) |
| 258 |
} |
| 259 |
if (!-e $pre_save_path.$domaindir."/".$user.$user_www_root) { |
| 260 |
mkdir ($pre_save_path.$domaindir."/".$user.$user_www_root) |
| 261 |
} |
| 262 |
if(!-e $homedir) { |
| 263 |
$homedir = "/dev/null"; |
| 264 |
return ($homedir); |
| 265 |
} |
| 266 |
else { |
| 267 |
qx (/bin/chown -R $user:$group $pre_save_path$domaindir"/"$user) |
| 268 |
#qx (/bin/chmod -R 750 $pre_save_path.$domaindir.$group_www_root) |
| 269 |
} |
| 270 |
if (!-e $pre_save_path.$domaindir.$group_www_root) { |
| 271 |
qx (/bin/cp -R $pre_save_path$template $pre_save_path$domaindir); |
| 272 |
qx (/bin/chown -R root:$group $pre_save_path$domaindir$group_www_root); |
| 273 |
#qx (/bin/chmod -R 750 $pre_save_path.$domaindir.$group_www_root) |
| 274 |
} |
| 275 |
} |
| 276 |
else { |
| 277 |
$homedir = "/dev/null"; |
| 278 |
return ($homedir); |
| 279 |
}} |
| 280 |
|
| 281 |
sub Group { |
| 282 |
#to implemented |
| 283 |
my $gid = shift; |
| 284 |
my $domain = shift; |
| 285 |
$domain =~ /(.*)\.(.*)/; |
| 286 |
my $group_name = $1."_".$2; |
| 287 |
qx (/usr/sbin/groupadd -g $gid $group_name); |
| 288 |
return ($group_name); |
| 289 |
} |
| 290 |
|
| 291 |
sub GetUserDataHTML { |
| 292 |
my %UserDaten; |
| 293 |
my $cgi = new CGI; |
| 294 |
my @Feldnamen = $cgi->param(); |
| 295 |
|
| 296 |
print $cgi->header(), |
| 297 |
$cgi->start_html('CGI-Feedback'), |
| 298 |
$cgi->h1('UMS-Feedback'); |
| 299 |
#,$cgi->i('comments.pl')); |
| 300 |
my @Feldinhalte; |
| 301 |
my $counter = 0; |
| 302 |
foreach my $Feld (@Feldnamen) { |
| 303 |
#print $cgi->b('Feldname: '), |
| 304 |
# $Feld, |
| 305 |
# $cgi->b(', Inhalt: '), |
| 306 |
# $cgi->param($Feld), "<br>"; |
| 307 |
@Feldinhalte[$counter]=$cgi->param($Feld); |
| 308 |
$counter++; |
| 309 |
} |
| 310 |
print $cgi->end_html(); |
| 311 |
|
| 312 |
my $vorname = @Feldinhalte[0]; |
| 313 |
my $nachname = @Feldinhalte[1]; |
| 314 |
my $username = @Feldinhalte[2]; |
| 315 |
my $password = @Feldinhalte[3]; |
| 316 |
my $domain = @Feldinhalte[4]; |
| 317 |
my $email = @Feldinhalte[5]; |
| 318 |
my $imap = @Feldinhalte[6]; |
| 319 |
$email = $email."\@".$domain; |
| 320 |
|
| 321 |
print $cgi->h1("$vorname"), |
| 322 |
$cgi->h1("$nachname"), |
| 323 |
$cgi->h1("$username"), |
| 324 |
$cgi->h1("$password"), |
| 325 |
$cgi->h1("$domain"), |
| 326 |
$cgi->h1("$email"), |
| 327 |
$cgi->h1("$imap"),"<br>"; |
| 328 |
|
| 329 |
my %UserDaten = (Vorname=>$vorname,Nachname=>$nachname,Domain=>$domain,Benutzername=>$username,Password=>$password,Imap=>$imap,EMail=>$email); |
| 330 |
return (%UserDaten); |
| 331 |
} |
| 332 |
|
| 333 |
sub SendmailConfig { |
| 334 |
my $user = shift; |
| 335 |
my $domain = shift; |
| 336 |
my $email = shift; |
| 337 |
|
| 338 |
open(DATEI, "<$virtualhost_file") || die "Datei nicht gefunden"; |
| 339 |
my @Zeilen = <DATEI>; |
| 340 |
close(DATEI); |
| 341 |
my @NeueZeilen; |
| 342 |
@NeueZeilen[0] = $email." ".$user."\n"; |
| 343 |
foreach(@NeueZeilen) { |
| 344 |
push(@Zeilen,$_); |
| 345 |
} |
| 346 |
open(DATEI, ">$virtualhost_file") || die "Datei nicht gefunden"; |
| 347 |
print DATEI @Zeilen; |
| 348 |
close(DATEI); |
| 349 |
|
| 350 |
$domain =~ /(.*)\.(.*)/; |
| 351 |
my $domain_dir = "/".$1."_".$2; |
| 352 |
if (!-e $mailuserpath.$domain_dir) { |
| 353 |
open(DATEI, "<$local_host_name_file") || die "Datei nicht gefunden"; |
| 354 |
my @Zeilen = <DATEI>; |
| 355 |
close(DATEI); |
| 356 |
my @NeueZeilen; |
| 357 |
@NeueZeilen[0] = $domain."\n"; |
| 358 |
foreach(@NeueZeilen) { |
| 359 |
push(@Zeilen,$_); |
| 360 |
} |
| 361 |
open(DATEI, ">$local_host_name_file") || die "Datei nicht gefunden"; |
| 362 |
print DATEI @Zeilen; |
| 363 |
close(DATEI); |
| 364 |
} |
| 365 |
|
| 366 |
open(DATEI, "<$genericstable_file") || die "Datei nicht gefunden"; |
| 367 |
my @Zeilen = <DATEI>; |
| 368 |
close(DATEI); |
| 369 |
my @NeueZeilen; |
| 370 |
@NeueZeilen[0] = $user." ".$email."\n"; |
| 371 |
foreach(@NeueZeilen) { |
| 372 |
push(@Zeilen,$_); |
| 373 |
} |
| 374 |
open(DATEI, ">$genericstable_file") || die "Datei nicht gefunden"; |
| 375 |
print DATEI @Zeilen; |
| 376 |
close(DATEI); |
| 377 |
sleep 2; |
| 378 |
chdir ($make_target); |
| 379 |
qx($make_bin); |
| 380 |
chdir ($current_dir); |
| 381 |
sleep 2; |
| 382 |
qx($remote_sendmail restart); |
| 383 |
sleep 2; |
| 384 |
} |
| 385 |
|
| 386 |
sub Main { |
| 387 |
my %UserData; |
| 388 |
if ($howtotell eq "TEST"){ |
| 389 |
%UserData = GetUserDataAuto(); |
| 390 |
} |
| 391 |
if ($howtotell eq "CMD"){ |
| 392 |
%UserData = GetUserDataCMD(); |
| 393 |
} |
| 394 |
if ($howtotell eq "HTML"){ |
| 395 |
%UserData = GetUserDataHTML(); |
| 396 |
} |
| 397 |
else { |
| 398 |
die; |
| 399 |
} |
| 400 |
my %UIDs = GetEnt_Passwd(); |
| 401 |
my $Group_Name = Group($UIDs{'GidNumber'},$UserData{'Domain'}); |
| 402 |
my $HomeDirGet = HomeDirGet($UserData{'Benutzername'},$UserData{'Domain'},$UserData{'Imap'}); |
| 403 |
CreateLDAPUser($UserData{'Benutzername'},$UserData{'Domain'},$UserData{'Password'},$UserData{'Nachname'},$UserData{'Vorname'},$UIDs{'UidNumber'},$UIDs{'GidNumber'},$HomeDirGet,$UserData{'Imap'},$UserData{'EMail'}); |
| 404 |
my $sendmail = SendmailConfig($UserData{'Benutzername'},$UserData{'Domain'},$UserData{'EMail'}); |
| 405 |
my $HomeDirMake = HomeDirMake($UserData{'Benutzername'},$UserData{'Domain'},$UserData{'Imap'},$UIDs{'UidNumber'},$UIDs{'GidNumber'},$Group_Name); |
| 406 |
} |