This commit was manufactured by cvs2svn to create branch 'freeside_import'.
[freeside.git] / htdocs / search / svc_acct_sm.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # svc_acct_sm.cgi: Search for domains (process form)
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 96-mar-5
11 #
12 # need to look at table in results to make it more readable
13 #
14 # ivan@voicenet.com
15 #
16 # rewrite ivan@sisd.com 98-mar-15
17 #
18 # Changes to allow page to work at a relative position in server
19 #       bmccane@maxbaud.net     98-apr-3
20
21 use strict;
22 use CGI::Request;
23 use CGI::Carp qw(fatalsToBrowser);
24 use FS::UID qw(cgisuidsetup);
25 use FS::Record qw(qsearch qsearchs);
26
27 my($conf_domain)="/var/spool/freeside/conf/domain";
28 open(DOMAIN,$conf_domain) or die "Can't open $conf_domain: $!";
29 my($mydomain)=map {
30   /^(.*)$/ or die "Illegal line in $conf_domain!"; #yes, we trust the file
31   $1
32 } grep $_ !~ /^(#|$)/, <DOMAIN>;
33 close DOMAIN;
34
35 my($req)=new CGI::Request; # create form object
36 &cgisuidsetup($req->cgi);
37
38 $req->param('domuser') =~ /^([a-z0-9_\-]{0,32})$/;
39 my($domuser)=$1;
40
41 $req->param('domain') =~ /^([\w\-\.]+)$/ or die "Illegal domain";
42 my($svc_domain)=qsearchs('svc_domain',{'domain'=>$1})
43   or die "Unknown domain";
44 my($domsvc)=$svc_domain->svcnum;
45
46 my(@svc_acct_sm);
47 if ($domuser) {
48   @svc_acct_sm=qsearch('svc_acct_sm',{
49     'domuser' => $domuser,
50     'domsvc'  => $domsvc,
51   });
52 } else {
53   @svc_acct_sm=qsearch('svc_acct_sm',{'domsvc' => $domsvc});
54 }
55
56 if ( scalar(@svc_acct_sm) == 1 ) {
57   my($svcnum)=$svc_acct_sm[0]->svcnum;
58   $req->cgi->redirect("../view/svc_acct_sm.cgi?$svcnum");  #redirect
59 } elsif ( scalar(@svc_acct_sm) > 1 ) {
60   CGI::Base::SendHeaders();
61   print <<END;
62 <HTML>
63   <HEAD>
64     <TITLE>Mail Alias Search Results</TITLE>
65   </HEAD>
66   <BODY>
67     <CENTER>
68     <H4>Mail Alias Search Results</H4>
69     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
70       <TR>
71         <TH>Mail to<BR><FONT SIZE=-2>(click here to view mail alias)</FONT></TH>
72         <TH>Forwards to<BR><FONT SIZE=-2>(click here to view account)</FONT></TH>
73       </TR>
74 END
75
76   my($svc_acct_sm);
77   foreach $svc_acct_sm (@svc_acct_sm) {
78     my($svcnum,$domuser,$domuid,$domsvc)=(
79       $svc_acct_sm->svcnum,
80       $svc_acct_sm->domuser,
81       $svc_acct_sm->domuid,
82       $svc_acct_sm->domsvc,
83     );
84     my($svc_domain)=qsearchs('svc_domain',{'svcnum'=>$domsvc});
85     my($domain)=$svc_domain->domain;
86     my($svc_acct)=qsearchs('svc_acct',{'uid'=>$domuid});
87     my($username)=$svc_acct->username;
88     my($svc_acct_svcnum)=$svc_acct->svcnum;
89
90     print <<END;
91 <TR>\n        <TD> <A HREF="../view/svc_acct_sm.cgi?$svcnum">
92 END
93
94     print '', ( ($domuser eq '*') ? "<I>(anything)</I>" : $domuser );
95
96     print <<END;
97 \@$domain</A> </TD>\n
98 <TD> <A HREF="../view/svc_acct.cgi?$svc_acct_svcnum">$username\@$mydomain</A> </TD>\n      </TR>\n
99 END
100
101   }
102
103   print <<END;
104       </TABLE>
105     </CENTER>
106   </BODY>
107 </HTML>
108 END
109
110 } else { #error
111   CGI::Base::SendHeaders(); # one guess
112   print <<END;
113 <HTML>
114   <HEAD>
115     <TITLE>Mail Alias Search Error</TITLE>
116   </HEAD>
117   <BODY>
118     <CENTER>
119     <H3>Mail Alias Search Error</H3>
120     <HR>
121     Mail Alias not found.
122     </CENTER>
123   </BODY>
124 </HTML>
125 END
126
127 }
128