<% my $conf = new FS::Conf; my $mydomain = $conf->config('domain'); my($query)=$cgi->keywords; $query ||= ''; #to avoid use of unitialized value errors my(@svc_domain,$sortby); if ( $query eq 'svcnum' ) { $sortby=\*svcnum_sort; @svc_domain=qsearch('svc_domain',{}); } elsif ( $query eq 'domain' ) { $sortby=\*domain_sort; @svc_domain=qsearch('svc_domain',{}); } elsif ( $query eq 'UN_svcnum' ) { $sortby=\*svcnum_sort; @svc_domain = grep qsearchs('cust_svc',{ 'svcnum' => $_->svcnum, 'pkgnum' => '', }), qsearch('svc_domain',{}); } elsif ( $query eq 'UN_domain' ) { $sortby=\*domain_sort; @svc_domain = grep qsearchs('cust_svc',{ 'svcnum' => $_->svcnum, 'pkgnum' => '', }), qsearch('svc_domain',{}); } else { $cgi->param('domain') =~ /^([\w\-\.]+)$/; my($domain)=$1; #push @svc_domain, qsearchs('svc_domain',{'domain'=>$domain}); @svc_domain = qsearchs('svc_domain',{'domain'=>$domain}); } if ( scalar(@svc_domain) == 1 ) { print $cgi->redirect(popurl(2). "view/svc_domain.cgi?". $svc_domain[0]->svcnum); #exit; } elsif ( scalar(@svc_domain) == 0 ) { %> <!-- mason kludge --> <% eidiot "No matching domains found!\n"; } else { %> <!-- mason kludge --> <% my($total)=scalar(@svc_domain); print header("Domain Search Results",''), <<END; $total matching domains found <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0> <TR> <TH>Service #</TH> <TH>Domain</TH> <TH>Mail to<BR><FONT SIZE=-1>(click to view account)</FONT></TH> <TH>Forwards to<BR><FONT SIZE=-1>(click to view account)</FONT></TH> </TR> END # my(%saw); # if we've multiple domains with the same # svcnum, then we've a corrupt database foreach my $svc_domain ( # sort $sortby grep(!$saw{$_->svcnum}++, @svc_domain) sort $sortby (@svc_domain) ) { my($svcnum,$domain)=( $svc_domain->svcnum, $svc_domain->domain, ); #my($malias); #if ( qsearch('svc_acct_sm',{'domsvc'=>$svcnum}) ) { # $malias=( # qq|<FORM ACTION="svc_acct_sm.cgi" METHOD="post">|. # qq|<INPUT TYPE="hidden" NAME="domuser" VALUE="">|. # qq|<INPUT TYPE="hidden" NAME="domain" VALUE="$domain">|. # qq|<INPUT TYPE="submit" VALUE="(mail aliases)">|. # qq|</FORM>| # ); #} else { # $malias=''; #} my @svc_acct=qsearch('svc_acct',{'domsvc' => $svcnum}); my $rowspan = 0; my $n1 = ''; my($svc_acct, @rows); foreach $svc_acct ( sort {$b->getfield('username') cmp $a->getfield('username')} (@svc_acct) ) { my (@forwards) = (); my($svcnum,$username)=( $svc_acct->svcnum, $svc_acct->username, ); my @svc_forward = qsearch( 'svc_forward', { 'srcsvc' => $svcnum } ); my $svc_forward; foreach $svc_forward (@svc_forward) { my($dstsvc,$dst) = ( $svc_forward->dstsvc, $svc_forward->dst, ); if ($dstsvc) { my $dst_svc_acct=qsearchs( 'svc_acct', { 'svcnum' => $dstsvc } ); my $destination=$dst_svc_acct->email; push @forwards, qq!<TD><A HREF="!, popurl(2), qq!view/svc_acct.cgi?$dstsvc">$destination</A>!, qq!</TD></TR>! ; }else{ push @forwards, qq!<TD>$dst</TD></TR>! ; } } push @rows, qq!$n1<TD ROWSPAN=!, (scalar(@svc_forward) || 1), qq!><A HREF="!. popurl(2). qq!view/svc_acct.cgi?$svcnum">!, #print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser ); ( ($username eq '*') ? "<I>(anything)</I>" : $username ), qq!\@$domain</A> </TD>!, ; push @rows, @forwards; $rowspan += (scalar(@svc_forward) || 1); $n1 = "</TR><TR>"; } #end of false laziness print <<END; <TR> <TD ROWSPAN=$rowspan><A HREF="${p}view/svc_domain.cgi?$svcnum"><FONT SIZE=-1>$svcnum</FONT></A></TD> <TD ROWSPAN=$rowspan>$domain</TD> END print @rows; print "</TR>"; } print <<END; </TABLE> </BODY> </HTML> END } sub svcnum_sort { $a->getfield('svcnum') <=> $b->getfield('svcnum'); } sub domain_sort { $a->getfield('domain') cmp $b->getfield('domain'); } %>