remove svc_acct_sm
[freeside.git] / httemplate / search / svc_domain.cgi
1 <%
2
3 my $conf = new FS::Conf;
4 my $mydomain = $conf->config('domain');
5
6 my($query)=$cgi->keywords;
7 $query ||= ''; #to avoid use of unitialized value errors
8 my(@svc_domain,$sortby);
9 if ( $query eq 'svcnum' ) {
10   $sortby=\*svcnum_sort;
11   @svc_domain=qsearch('svc_domain',{});
12 } elsif ( $query eq 'domain' ) {
13   $sortby=\*domain_sort;
14   @svc_domain=qsearch('svc_domain',{});
15 } elsif ( $query eq 'UN_svcnum' ) {
16   $sortby=\*svcnum_sort;
17   @svc_domain = grep qsearchs('cust_svc',{
18       'svcnum' => $_->svcnum,
19       'pkgnum' => '',
20     }), qsearch('svc_domain',{});
21 } elsif ( $query eq 'UN_domain' ) {
22   $sortby=\*domain_sort;
23   @svc_domain = grep qsearchs('cust_svc',{
24       'svcnum' => $_->svcnum,
25       'pkgnum' => '',
26     }), qsearch('svc_domain',{});
27 } else {
28   $cgi->param('domain') =~ /^([\w\-\.]+)$/; 
29   my($domain)=$1;
30   #push @svc_domain, qsearchs('svc_domain',{'domain'=>$domain});
31   @svc_domain = qsearchs('svc_domain',{'domain'=>$domain});
32 }
33
34 if ( scalar(@svc_domain) == 1 ) {
35   print $cgi->redirect(popurl(2). "view/svc_domain.cgi?". $svc_domain[0]->svcnum);
36   #exit;
37 } elsif ( scalar(@svc_domain) == 0 ) {
38 %>
39 <!-- mason kludge -->
40 <%
41   eidiot "No matching domains found!\n";
42 } else {
43 %>
44 <!-- mason kludge -->
45 <%
46   my($total)=scalar(@svc_domain);
47   print header("Domain Search Results",''), <<END;
48
49     $total matching domains found
50     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
51       <TR>
52         <TH>Service #</TH>
53         <TH>Domain</TH>
54         <TH>Mail to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
55         <TH>Forwards to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
56       </TR>
57 END
58
59 #  my(%saw);                 # if we've multiple domains with the same
60                              # svcnum, then we've a corrupt database
61
62   foreach my $svc_domain (
63 #    sort $sortby grep(!$saw{$_->svcnum}++, @svc_domain)
64     sort $sortby (@svc_domain)
65   ) {
66     my($svcnum,$domain)=(
67       $svc_domain->svcnum,
68       $svc_domain->domain,
69     );
70
71     my @svc_acct=qsearch('svc_acct',{'domsvc' => $svcnum});
72     my $rowspan = 0;
73
74     my $n1 = '';
75     my($svc_acct, @rows);
76     foreach $svc_acct (
77       sort {$b->getfield('username') cmp $a->getfield('username')} (@svc_acct)
78     ) {
79
80       my (@forwards) = ();
81
82       my($svcnum,$username)=(
83         $svc_acct->svcnum,
84         $svc_acct->username,
85       );
86
87       my @svc_forward = qsearch( 'svc_forward', { 'srcsvc' => $svcnum } );
88       my $svc_forward;
89       foreach $svc_forward (@svc_forward) {
90         my($dstsvc,$dst) = (
91           $svc_forward->dstsvc,
92           $svc_forward->dst,
93         );
94         if ($dstsvc) {
95           my $dst_svc_acct=qsearchs( 'svc_acct', { 'svcnum' => $dstsvc } );
96           my $destination=$dst_svc_acct->email;
97           push @forwards, qq!<TD><A HREF="!, popurl(2),
98                 qq!view/svc_acct.cgi?$dstsvc">$destination</A>!,
99                 qq!</TD></TR>!
100           ;
101         }else{
102           push @forwards, qq!<TD>$dst</TD></TR>!
103           ;
104         }
105       }
106
107       push @rows, qq!$n1<TD ROWSPAN=!, (scalar(@svc_forward) || 1),
108             qq!><A HREF="!. popurl(2). qq!view/svc_acct.cgi?$svcnum">!,
109       #print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser );
110             ( ($username eq '*') ? "<I>(anything)</I>" : $username ),
111             qq!\@$domain</A> </TD>!,
112       ;
113
114       push @rows, @forwards;
115
116       $rowspan += (scalar(@svc_forward) || 1);
117       $n1 = "</TR><TR>";
118     }
119     #end of false laziness
120
121
122
123     print <<END;
124     <TR>
125       <TD ROWSPAN=$rowspan><A HREF="${p}view/svc_domain.cgi?$svcnum"><FONT SIZE=-1>$svcnum</FONT></A></TD>
126       <TD ROWSPAN=$rowspan>$domain</TD>
127 END
128
129     print @rows;
130     print "</TR>";
131
132   }
133  
134   print <<END;
135     </TABLE>
136   </BODY>
137 </HTML>
138 END
139
140 }
141
142 sub svcnum_sort {
143   $a->getfield('svcnum') <=> $b->getfield('svcnum');
144 }
145
146 sub domain_sort {
147   $a->getfield('domain') cmp $b->getfield('domain');
148 }
149
150
151 %>