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