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