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