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