fb372db1416099d001fc6264aa606891ad410d92
[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     #my($malias);
71     #if ( qsearch('svc_acct_sm',{'domsvc'=>$svcnum}) ) {
72     #  $malias=(
73     #    qq|<FORM ACTION="svc_acct_sm.cgi" METHOD="post">|.
74     #      qq|<INPUT TYPE="hidden" NAME="domuser" VALUE="">|.
75     #      qq|<INPUT TYPE="hidden" NAME="domain" VALUE="$domain">|.
76     #      qq|<INPUT TYPE="submit" VALUE="(mail aliases)">|.
77     #      qq|</FORM>|
78     #  );
79     #} else {
80     #  $malias='';
81     #}
82
83     my @svc_acct=qsearch('svc_acct',{'domsvc' => $svcnum});
84     my $rowspan = 0;
85
86     my $n1 = '';
87     my($svc_acct, @rows);
88     foreach $svc_acct (
89       sort {$b->getfield('username') cmp $a->getfield('username')} (@svc_acct)
90     ) {
91
92       my (@forwards) = ();
93
94       my($svcnum,$username)=(
95         $svc_acct->svcnum,
96         $svc_acct->username,
97       );
98
99       my @svc_forward = qsearch( 'svc_forward', { 'srcsvc' => $svcnum } );
100       my $svc_forward;
101       foreach $svc_forward (@svc_forward) {
102         my($dstsvc,$dst) = (
103           $svc_forward->dstsvc,
104           $svc_forward->dst,
105         );
106         if ($dstsvc) {
107           my $dst_svc_acct=qsearchs( 'svc_acct', { 'svcnum' => $dstsvc } );
108           my $destination=$dst_svc_acct->email;
109           push @forwards, qq!<TD><A HREF="!, popurl(2),
110                 qq!view/svc_acct.cgi?$dstsvc">$destination</A>!,
111                 qq!</TD></TR>!
112           ;
113         }else{
114           push @forwards, qq!<TD>$dst</TD></TR>!
115           ;
116         }
117       }
118
119       push @rows, qq!$n1<TD ROWSPAN=!, (scalar(@svc_forward) || 1),
120             qq!><A HREF="!. popurl(2). qq!view/svc_acct.cgi?$svcnum">!,
121       #print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser );
122             ( ($username eq '*') ? "<I>(anything)</I>" : $username ),
123             qq!\@$domain</A> </TD>!,
124       ;
125
126       push @rows, @forwards;
127
128       $rowspan += (scalar(@svc_forward) || 1);
129       $n1 = "</TR><TR>";
130     }
131     #end of false laziness
132
133
134
135     print <<END;
136     <TR>
137       <TD ROWSPAN=$rowspan><A HREF="${p}view/svc_domain.cgi?$svcnum"><FONT SIZE=-1>$svcnum</FONT></A></TD>
138       <TD ROWSPAN=$rowspan>$domain</TD>
139 END
140
141     print @rows;
142     print "</TR>";
143
144   }
145  
146   print <<END;
147     </TABLE>
148   </BODY>
149 </HTML>
150 END
151
152 }
153
154 sub svcnum_sort {
155   $a->getfield('svcnum') <=> $b->getfield('svcnum');
156 }
157
158 sub domain_sort {
159   $a->getfield('domain') cmp $b->getfield('domain');
160 }
161
162
163 %>