templates!!!
[freeside.git] / httemplate / search / svc_domain.cgi
1 <%
2 #
3 # $Id: svc_domain.cgi,v 1.1 2001-07-30 07:36:04 ivan Exp $
4 #
5 # Usage: post form to:
6 #        http://server.name/path/svc_domain.cgi
7 #
8 # ivan@voicenet.com 97-mar-5
9 #
10 # rewrite ivan@sisd.com 98-mar-14
11 #
12 # Changes to allow page to work at a relative position in server
13 #       bmccane@maxbaud.net     98-apr-3
14 #
15 # display total, use FS::CGI now does browsing too ivan@sisd.com 98-jul-17
16 #
17 # $Log: svc_domain.cgi,v $
18 # Revision 1.1  2001-07-30 07:36:04  ivan
19 # templates!!!
20 #
21 # Revision 1.11  2000/03/03 18:22:44  ivan
22 # changes from 1.2.3 release, fixes from webdemo
23 #
24 # Revision 1.10  1999/07/17 10:38:52  ivan
25 # scott nelson <scott@ultimanet.com> noticed this mod_perl-triggered bug and
26 # gave me a great bugreport at the last rhythmethod
27 #
28 # Revision 1.9  1999/04/15 13:39:16  ivan
29 # $cgi->header( '-expires' => 'now' )
30 #
31 # Revision 1.8  1999/02/28 00:03:57  ivan
32 # removed misleading comments
33 #
34 # Revision 1.7  1999/02/23 08:09:24  ivan
35 # beginnings of one-screen new customer entry and some other miscellania
36 #
37 # Revision 1.6  1999/02/09 09:22:59  ivan
38 # visual and bugfixes
39 #
40 # Revision 1.5  1999/02/07 09:59:39  ivan
41 # more mod_perl fixes, and bugfixes Peter Wemm sent via email
42 #
43 # Revision 1.4  1999/01/19 05:14:17  ivan
44 # for mod_perl: no more top-level my() variables; use vars instead
45 # also the last s/create/new/;
46 #
47 # Revision 1.3  1998/12/23 03:06:50  ivan
48 # $cgi->keywords instead of $cgi->query_string
49 #
50 # Revision 1.2  1998/12/17 09:41:12  ivan
51 # s/CGI::(Base|Request)/CGI.pm/;
52 #
53
54 use strict;
55 use vars qw ( $cgi @svc_domain $sortby $query $conf $mydomain );
56 use CGI;
57 use CGI::Carp qw(fatalsToBrowser);
58 use FS::UID qw(cgisuidsetup);
59 use FS::Record qw(qsearch qsearchs);
60 use FS::CGI qw(header eidiot popurl);
61 use FS::svc_domain;
62 use FS::cust_svc;
63 use FS::svc_acct_sm;
64 use FS::svc_acct;
65
66 $cgi = new CGI;
67 &cgisuidsetup($cgi);
68
69 $conf = new FS::Conf;
70 $mydomain = $conf->config('domain');
71
72 ($query)=$cgi->keywords;
73 $query ||= ''; #to avoid use of unitialized value errors
74 if ( $query eq 'svcnum' ) {
75   $sortby=\*svcnum_sort;
76   @svc_domain=qsearch('svc_domain',{});
77 } elsif ( $query eq 'domain' ) {
78   $sortby=\*domain_sort;
79   @svc_domain=qsearch('svc_domain',{});
80 } elsif ( $query eq 'UN_svcnum' ) {
81   $sortby=\*svcnum_sort;
82   @svc_domain = grep qsearchs('cust_svc',{
83       'svcnum' => $_->svcnum,
84       'pkgnum' => '',
85     }), qsearch('svc_domain',{});
86 } elsif ( $query eq 'UN_domain' ) {
87   $sortby=\*domain_sort;
88   @svc_domain = grep qsearchs('cust_svc',{
89       'svcnum' => $_->svcnum,
90       'pkgnum' => '',
91     }), qsearch('svc_domain',{});
92 } else {
93   $cgi->param('domain') =~ /^([\w\-\.]+)$/; 
94   my($domain)=$1;
95   #push @svc_domain, qsearchs('svc_domain',{'domain'=>$domain});
96   @svc_domain = qsearchs('svc_domain',{'domain'=>$domain});
97 }
98
99 if ( scalar(@svc_domain) == 1 ) {
100   print $cgi->redirect(popurl(2). "view/svc_domain.cgi?". $svc_domain[0]->svcnum);
101   exit;
102 } elsif ( scalar(@svc_domain) == 0 ) {
103   eidiot "No matching domains found!\n";
104 } else {
105
106   my($total)=scalar(@svc_domain);
107   print $cgi->header( '-expires' => 'now' ),
108         header("Domain Search Results",''), <<END;
109
110     $total matching domains found
111     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
112       <TR>
113         <TH>Service #</TH>
114         <TH>Domain</TH>
115         <TH>Mail to<BR><FONT SIZE=-1>(click to view mail alias)</FONT></TH>
116         <TH>Forwards to<BR><FONT SIZE=-1>(click to view account)</FONT></TH>
117       </TR>
118 END
119
120   my(%saw,$svc_domain);
121   my $p = popurl(2);
122   foreach $svc_domain (
123     sort $sortby grep(!$saw{$_->svcnum}++, @svc_domain)
124   ) {
125     my($svcnum,$domain)=(
126       $svc_domain->svcnum,
127       $svc_domain->domain,
128     );
129     #my($malias);
130     #if ( qsearch('svc_acct_sm',{'domsvc'=>$svcnum}) ) {
131     #  $malias=(
132     #    qq|<FORM ACTION="svc_acct_sm.cgi" METHOD="post">|.
133     #      qq|<INPUT TYPE="hidden" NAME="domuser" VALUE="">|.
134     #      qq|<INPUT TYPE="hidden" NAME="domain" VALUE="$domain">|.
135     #      qq|<INPUT TYPE="submit" VALUE="(mail aliases)">|.
136     #      qq|</FORM>|
137     #  );
138     #} else {
139     #  $malias='';
140     #}
141
142     my @svc_acct_sm=qsearch('svc_acct_sm',{'domsvc' => $svcnum});
143     my $rowspan = scalar(@svc_acct_sm) || 1;
144
145     print <<END;
146     <TR>
147       <TD ROWSPAN=$rowspan><A HREF="${p}view/svc_domain.cgi?$svcnum"><FONT SIZE=-1>$svcnum</FONT></A></TD>
148       <TD ROWSPAN=$rowspan>$domain</TD>
149 END
150
151     my $n1 = '';
152     # false laziness: this was stolen from search/svc_acct_sm.cgi.  but the
153     # web interface in general needs to be rewritten in a mucho cleaner way
154     my($svc_acct_sm);
155     foreach $svc_acct_sm (@svc_acct_sm) {
156       my($svcnum,$domuser,$domuid,$domsvc)=(
157         $svc_acct_sm->svcnum,
158         $svc_acct_sm->domuser,
159         $svc_acct_sm->domuid,
160         $svc_acct_sm->domsvc,
161       );
162       #my $svc_domain = qsearchs( 'svc_domain', { 'svcnum' => $domsvc } );
163       #if ( $svc_domain ) {
164       #  my $domain = $svc_domain->domain;
165
166         print qq!$n1<TD><A HREF="!. popurl(2). qq!view/svc_acct_sm.cgi?$svcnum">!,
167         #print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser );
168               ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser ),
169               qq!\@$domain</A> </TD>!,
170         ;
171       #} else {
172       #  my $warning = "couldn't find svc_domain.svcnum $svcnum ( svc_acct_sm.svcnum $svcnum";
173       #  warn $warning;
174       #  print "$n1<TD>WARNING: $warning</TD>";
175       #}
176
177       my $svc_acct = qsearchs( 'svc_acct', { 'uid' => $domuid } );
178       if ( $svc_acct ) {
179         my $username = $svc_acct->username;
180         my $svc_acct_svcnum =$svc_acct->svcnum;
181         print qq!<TD><A HREF="!, popurl(2),
182               qq!view/svc_acct.cgi?$svc_acct_svcnum">$username\@$mydomain</A>!,
183               qq!</TD></TR>!
184         ;
185       } else {
186         my $warning = "couldn't find svc_acct.uid $domuid (svc_acct_sm.svcnum $svcnum)!";
187         warn $warning;
188         print "<TD>WARNING: $warning</TD>";
189       }
190       $n1 = "</TR><TR>";
191     }
192     #end of false laziness
193     print "</TR>";
194
195   }
196  
197   print <<END;
198     </TABLE>
199   </BODY>
200 </HTML>
201 END
202
203 }
204
205 sub svcnum_sort {
206   $a->getfield('svcnum') <=> $b->getfield('svcnum');
207 }
208
209 sub domain_sort {
210   $a->getfield('domain') cmp $b->getfield('doimain');
211 }
212
213
214 %>