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