X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=bin%2Fsvc_acct.export;h=8c408a2e8d5b86b9d8d4099cf704c1418aaf23df;hb=03dcc6e0f48fae0b892dbd36229884e684b94049;hp=a7a21b3e58005cd1f95b2d380c783a794adda86a;hpb=4d513ff5a17bd3b697502b54c9516577a0a8d3e4;p=freeside.git diff --git a/bin/svc_acct.export b/bin/svc_acct.export index a7a21b3e5..8c408a2e8 100755 --- a/bin/svc_acct.export +++ b/bin/svc_acct.export @@ -1,18 +1,11 @@ #!/usr/bin/perl -w # -# $Id: svc_acct.export,v 1.22 2001-08-12 19:41:25 jeff Exp $ +# $Id: svc_acct.export,v 1.27 2001-12-11 10:38:56 ivan Exp $ # # Create and export password, radius and vpopmail password files: # passwd, passwd.adjunct, shadow, acp_passwd, acp_userinfo, acp_dialup # users/assign, domains/vdomain/vpasswd # Also export sendmail and qmail config files. -# -# -# $Log: svc_acct.export,v $ -# Revision 1.22 2001-08-12 19:41:25 jeff -# merging vpopmail support branch -# -# use strict; use vars qw($conf); @@ -55,7 +48,7 @@ my @radiusmachines = $conf->config('radiusmachines') my $icradiusmachines = $conf->exists('icradiusmachines'); my @icradiusmachines = $conf->config('icradiusmachines') if $icradiusmachines; my $icradius_mysqldest = - $conf->config('icradius_mysqldest') || "/usr/local/var/" + $conf->config('icradius_mysqldest') || "/usr/local/var" if $icradiusmachines; my $icradius_mysqlsource = $conf->config('icradius_mysqlsource') || "/usr/local/var/freeside" @@ -63,7 +56,7 @@ my $icradius_mysqlsource = my $icradius_dbh; if ( $icradiusmachines && $conf->exists('icradius_secrets') ) { $icradius_dbh = DBI->connect($conf->config('icradius_secrets')) - or die $DBI::errstr;; + or die $DBI::errstr; } else { $icradius_dbh = dbh; } @@ -73,10 +66,21 @@ my $textradiusprepend = ? $conf->config('textradiusprepend') : ''; +warn "using depriciated textradiusprepend file" if $textradiusprepend; + + +my $radiusprepend = + $conf->exists('radiusprepend') + ? $conf->config('radiusprepend') + : ''; + my @vpopmailmachines = $conf->config('vpopmailmachines') if $conf->exists('vpopmailmachines'); +my $vpopmailrestart = ''; +$vpopmailrestart = $conf->config('vpopmailrestart') + if $conf->exists('vpopmailrestart'); -my ($machine, $vpopdir, $vpopuid, $vpopgid) = split (/\s+/, $vpopmailmachines[0]); +my ($machine, $vpopdir, $vpopuid, $vpopgid) = split (/\s+/, $vpopmailmachines[0]) if $vpopmailmachines[0]; my($shellmachine, @qmailmachines); if ( $conf->exists('qmailmachines') ) { @@ -192,6 +196,8 @@ if ( $icradiusmachines ) { setpriority(0,0,10); +print USERS "$radiusprepend\n"; + my %usernames; ## this hack helps keep the passwd files sane my @sendmail; @@ -214,7 +220,7 @@ foreach $svc_domain (sort {$a->domain cmp $b->domain} @svc_domain) { "-", "", "", - ), "\n"; + ), "\n" if $vpopmailmachines[0]; (mkdir "$spooldir/domains/" . $domain, 0700) or die "Can't create $spooldir/domains/" . $domain .": $!"; @@ -229,7 +235,7 @@ foreach $svc_domain (sort {$a->domain cmp $b->domain} @svc_domain) { my ($svc_acct); - if ($svc_domain->catchall) { + if ($svc_domain->getfield('catchall')) { $svc_acct = qsearchs('svc_acct', {'svcnum' => $svc_domain->catchall}); die "Cannot find catchall account for domain $domain\n" unless $svc_acct; @@ -241,12 +247,14 @@ foreach $svc_domain (sort {$a->domain cmp $b->domain} @svc_domain) { ### # FORMAT OF THE .QMAIL-DEFAULT FILE HERE - print QMAILDEFAULT "| $vpopdir/bin/vdelivermail \"\" $username\@$domain\n"; + print QMAILDEFAULT "| $vpopdir/bin/vdelivermail \"\" " . $svc_acct->email . "\n" + if $vpopmailmachines[0]; }else{ ### # FORMAT OF THE .QMAIL-DEFAULT FILE HERE - print QMAILDEFAULT "| $vpopdir/bin/vdelivermail \"\" bounce-no-mailbox\n"; + print QMAILDEFAULT "| $vpopdir/bin/vdelivermail \"\" bounce-no-mailbox\n" + if $vpopmailmachines[0]; } print VPOPVIRTUALDOMAINS "$domain:$domain\n"; @@ -254,7 +262,8 @@ foreach $svc_domain (sort {$a->domain cmp $b->domain} @svc_domain) { foreach $svc_acct (qsearch('svc_acct', {'domsvc' => $svc_domain->svcnum})) { my($password)=$svc_acct->getfield('_password'); my($cpassword,$rpassword); - if ( ( length($password) <= 8 ) + #if ( ( length($password) <= 8 ) + if ( ( length($password) <= 12 ) && ( $password ne '*' ) && ( $password ne '!!' ) && ( $password ne '' ) @@ -432,6 +441,18 @@ foreach $svc_domain (sort {$a->domain cmp $b->domain} @svc_domain) { ) ). " )" ); $sth->execute or die "Can't insert into radreply table: ". $sth->errstr; } + + if ( $ip && $ip ne '0e0' ) { + my $sth = $icradius_dbh->prepare( + "INSERT INTO radreply (id, UserName, Attribute, Value) VALUES ( ". + join(", ", map { $icradius_dbh->quote( $_ ) } ( + '', + $username, + 'Framed-IP-Address', + $ip, + ) ). " )" + ); + $sth->execute or die "Can't insert into radreply table: ". $sth->errstr; } } } @@ -649,6 +670,15 @@ foreach $vpopmailmachine (@vpopmailmachines) { or die "scp error: ". $scp->{errstr}; $scp->scp("$spooldir/vpoprcpthosts","root\@$machine:/var/qmail/control/rcpthosts") or die "scp error: ". $scp->{errstr}; + + ssh("root\@$machine", + "( ". + $vpopmailrestart . + " )" + ) + == 0 or die "ssh error: $!"; + + } my($sendmailmachine);