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