remove $Log$ messages. whew.
[freeside.git] / httemplate / search / svc_domain.cgi
1 <%
2 # <!-- $Id: svc_domain.cgi,v 1.3 2001-08-21 02:31:57 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 $cgi->header( '-expires' => 'now' ),
58         header("Domain Search Results",''), <<END;
59
60     $total matching domains found
61     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
62       <TR>
63         <TH>Service #</TH>
64         <TH>Domain</TH>
65         <TH>Mail to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
66         <TH>Forwards to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
67       </TR>
68 END
69
70 #  my(%saw);                 # if we've multiple domains with the same
71                              # svcnum, then we've a corrupt database
72
73   my($svc_domain);
74   my $p = popurl(2);
75   foreach $svc_domain (
76 #    sort $sortby grep(!$saw{$_->svcnum}++, @svc_domain)
77     sort $sortby (@svc_domain)
78   ) {
79     my($svcnum,$domain)=(
80       $svc_domain->svcnum,
81       $svc_domain->domain,
82     );
83     #my($malias);
84     #if ( qsearch('svc_acct_sm',{'domsvc'=>$svcnum}) ) {
85     #  $malias=(
86     #    qq|<FORM ACTION="svc_acct_sm.cgi" METHOD="post">|.
87     #      qq|<INPUT TYPE="hidden" NAME="domuser" VALUE="">|.
88     #      qq|<INPUT TYPE="hidden" NAME="domain" VALUE="$domain">|.
89     #      qq|<INPUT TYPE="submit" VALUE="(mail aliases)">|.
90     #      qq|</FORM>|
91     #  );
92     #} else {
93     #  $malias='';
94     #}
95
96     my @svc_acct=qsearch('svc_acct',{'domsvc' => $svcnum});
97     my $rowspan = 0;
98
99     my $n1 = '';
100     my($svc_acct, @rows);
101     foreach $svc_acct (
102       sort {$b->getfield('username') cmp $a->getfield('username')} (@svc_acct)
103     ) {
104
105       my (@forwards) = ();
106
107       my($svcnum,$username)=(
108         $svc_acct->svcnum,
109         $svc_acct->username,
110       );
111
112       my @svc_forward = qsearch( 'svc_forward', { 'srcsvc' => $svcnum } );
113       my $svc_forward;
114       foreach $svc_forward (@svc_forward) {
115         my($dstsvc,$dst) = (
116           $svc_forward->dstsvc,
117           $svc_forward->dst,
118         );
119         if ($dstsvc) {
120           my $dst_svc_acct=qsearchs( 'svc_acct', { 'svcnum' => $dstsvc } );
121           my $destination=$dst_svc_acct->email;
122           push @forwards, qq!<TD><A HREF="!, popurl(2),
123                 qq!view/svc_acct.cgi?$dstsvc">$destination</A>!,
124                 qq!</TD></TR>!
125           ;
126         }else{
127           push @forwards, qq!<TD>$dst</TD></TR>!
128           ;
129         }
130       }
131
132       push @rows, qq!$n1<TD ROWSPAN=!, (scalar(@svc_forward) || 1),
133             qq!><A HREF="!. popurl(2). qq!view/svc_acct.cgi?$svcnum">!,
134       #print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser );
135             ( ($username eq '*') ? "<I>(anything)</I>" : $username ),
136             qq!\@$domain</A> </TD>!,
137       ;
138
139       push @rows, @forwards;
140
141       $rowspan += (scalar(@svc_forward) || 1);
142       $n1 = "</TR><TR>";
143     }
144     #end of false laziness
145
146
147
148     print <<END;
149     <TR>
150       <TD ROWSPAN=$rowspan><A HREF="${p}view/svc_domain.cgi?$svcnum"><FONT SIZE=-1>$svcnum</FONT></A></TD>
151       <TD ROWSPAN=$rowspan>$domain</TD>
152 END
153
154     print @rows;
155     print "</TR>";
156
157   }
158  
159   print <<END;
160     </TABLE>
161   </BODY>
162 </HTML>
163 END
164
165 }
166
167 sub svcnum_sort {
168   $a->getfield('svcnum') <=> $b->getfield('svcnum');
169 }
170
171 sub domain_sort {
172   $a->getfield('domain') cmp $b->getfield('domain');
173 }
174
175
176 %>