removed <!-- $Id$ --> from all files to fix any redirects, whew
[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   eidiot "No matching domains found!\n";
39 } else {
40
41   my($total)=scalar(@svc_domain);
42   print header("Domain Search Results",''), <<END;
43
44     $total matching domains found
45     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
46       <TR>
47         <TH>Service #</TH>
48         <TH>Domain</TH>
49         <TH>Mail to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
50         <TH>Forwards to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
51       </TR>
52 END
53
54 #  my(%saw);                 # if we've multiple domains with the same
55                              # svcnum, then we've a corrupt database
56
57   foreach my $svc_domain (
58 #    sort $sortby grep(!$saw{$_->svcnum}++, @svc_domain)
59     sort $sortby (@svc_domain)
60   ) {
61     my($svcnum,$domain)=(
62       $svc_domain->svcnum,
63       $svc_domain->domain,
64     );
65     #my($malias);
66     #if ( qsearch('svc_acct_sm',{'domsvc'=>$svcnum}) ) {
67     #  $malias=(
68     #    qq|<FORM ACTION="svc_acct_sm.cgi" METHOD="post">|.
69     #      qq|<INPUT TYPE="hidden" NAME="domuser" VALUE="">|.
70     #      qq|<INPUT TYPE="hidden" NAME="domain" VALUE="$domain">|.
71     #      qq|<INPUT TYPE="submit" VALUE="(mail aliases)">|.
72     #      qq|</FORM>|
73     #  );
74     #} else {
75     #  $malias='';
76     #}
77
78     my @svc_acct=qsearch('svc_acct',{'domsvc' => $svcnum});
79     my $rowspan = 0;
80
81     my $n1 = '';
82     my($svc_acct, @rows);
83     foreach $svc_acct (
84       sort {$b->getfield('username') cmp $a->getfield('username')} (@svc_acct)
85     ) {
86
87       my (@forwards) = ();
88
89       my($svcnum,$username)=(
90         $svc_acct->svcnum,
91         $svc_acct->username,
92       );
93
94       my @svc_forward = qsearch( 'svc_forward', { 'srcsvc' => $svcnum } );
95       my $svc_forward;
96       foreach $svc_forward (@svc_forward) {
97         my($dstsvc,$dst) = (
98           $svc_forward->dstsvc,
99           $svc_forward->dst,
100         );
101         if ($dstsvc) {
102           my $dst_svc_acct=qsearchs( 'svc_acct', { 'svcnum' => $dstsvc } );
103           my $destination=$dst_svc_acct->email;
104           push @forwards, qq!<TD><A HREF="!, popurl(2),
105                 qq!view/svc_acct.cgi?$dstsvc">$destination</A>!,
106                 qq!</TD></TR>!
107           ;
108         }else{
109           push @forwards, qq!<TD>$dst</TD></TR>!
110           ;
111         }
112       }
113
114       push @rows, qq!$n1<TD ROWSPAN=!, (scalar(@svc_forward) || 1),
115             qq!><A HREF="!. popurl(2). qq!view/svc_acct.cgi?$svcnum">!,
116       #print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser );
117             ( ($username eq '*') ? "<I>(anything)</I>" : $username ),
118             qq!\@$domain</A> </TD>!,
119       ;
120
121       push @rows, @forwards;
122
123       $rowspan += (scalar(@svc_forward) || 1);
124       $n1 = "</TR><TR>";
125     }
126     #end of false laziness
127
128
129
130     print <<END;
131     <TR>
132       <TD ROWSPAN=$rowspan><A HREF="${p}view/svc_domain.cgi?$svcnum"><FONT SIZE=-1>$svcnum</FONT></A></TD>
133       <TD ROWSPAN=$rowspan>$domain</TD>
134 END
135
136     print @rows;
137     print "</TR>";
138
139   }
140  
141   print <<END;
142     </TABLE>
143   </BODY>
144 </HTML>
145 END
146
147 }
148
149 sub svcnum_sort {
150   $a->getfield('svcnum') <=> $b->getfield('svcnum');
151 }
152
153 sub domain_sort {
154   $a->getfield('domain') cmp $b->getfield('domain');
155 }
156
157
158 %>