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