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