added user interface for svc_forward and vpopmail support
[freeside.git] / httemplate / edit / svc_forward.cgi
1 <%
2 #
3 # $Id: svc_forward.cgi,v 1.1 2001-08-19 15:53:35 jeff Exp $
4 #
5 # Usage: svc_forward.cgi {svcnum} | pkgnum{pkgnum}-svcpart{svcpart}
6 #        http://server.name/path/svc_forward.cgi? {svcnum} | pkgnum{pkgnum}-svcpart{svcpart}
7 #
8 # use {svcnum} for edit, pkgnum{pkgnum}-svcpart{svcpart} for add
9 #
10 # should error out in a more CGI-friendly way, and should have more error checking (sigh).
11 #
12 # $Log: svc_forward.cgi,v $
13 # Revision 1.1  2001-08-19 15:53:35  jeff
14 # added user interface for svc_forward and vpopmail support
15 #
16 #
17
18 use strict;
19 use vars qw( $conf $cgi $mydomain $action $svcnum $svc_forward $pkgnum $svcpart
20              $part_svc $query %email $p1 $srcsvc $dstsvc $dst );
21 use CGI;
22 use CGI::Carp qw(fatalsToBrowser);
23 use FS::UID qw(cgisuidsetup);
24 use FS::CGI qw(header popurl);
25 use FS::Record qw(qsearch qsearchs fields);
26 use FS::svc_forward;
27 use FS::Conf;
28
29 $cgi = new CGI;
30 &cgisuidsetup($cgi);
31
32 $conf = new FS::Conf;
33 $mydomain = $conf->config('domain');
34
35 if ( $cgi->param('error') ) {
36   $svc_forward = new FS::svc_forward ( {
37     map { $_, scalar($cgi->param($_)) } fields('svc_forward')
38   } );
39   $svcnum = $svc_forward->svcnum;
40   $pkgnum = $cgi->param('pkgnum');
41   $svcpart = $cgi->param('svcpart');
42   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
43   die "No part_svc entry!" unless $part_svc;
44 } else {
45   my($query) = $cgi->keywords;
46   if ( $query =~ /^(\d+)$/ ) { #editing
47     $svcnum=$1;
48     $svc_forward=qsearchs('svc_forward',{'svcnum'=>$svcnum})
49       or die "Unknown (svc_forward) svcnum!";
50
51     my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
52       or die "Unknown (cust_svc) svcnum!";
53
54     $pkgnum=$cust_svc->pkgnum;
55     $svcpart=$cust_svc->svcpart;
56   
57     $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
58     die "No part_svc entry!" unless $part_svc;
59
60   } else { #adding
61
62     $svc_forward = new FS::svc_forward({});
63
64     foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart
65       $pkgnum=$1 if /^pkgnum(\d+)$/;
66       $svcpart=$1 if /^svcpart(\d+)$/;
67     }
68     $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
69     die "No part_svc entry!" unless $part_svc;
70
71     $svcnum='';
72
73     #set fixed and default fields from part_svc
74     my($field);
75     foreach $field ( fields('svc_forward') ) {
76       if ( $part_svc->getfield('svc_forward__'. $field. '_flag') ne '' ) {
77         $svc_forward->setfield($field,$part_svc->getfield('svc_forward__'. $field) );
78       }
79     }
80
81   }
82 }
83 $action = $svc_forward->svcnum ? 'Edit' : 'Add';
84
85 if ($pkgnum) {
86
87   #find all possible user svcnums (and emails)
88
89   #starting with those currently attached
90   my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svc_forward->srcsvc});
91   $email{$svc_forward->srcsvc} = $svc_acct->email;
92
93   if ($svc_forward->dstsvc) {
94     $svc_acct=qsearchs('svc_acct',{'svcnum'=>$svc_forward->dstsvc});
95     $email{$svc_forward->dstsvc} = $svc_acct->email;
96   }
97
98   #and including the rest for this customer
99   my($u_part_svc,@u_acct_svcparts);
100   foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
101     push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
102   }
103
104   my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
105   my($custnum)=$cust_pkg->getfield('custnum');
106   my($i_cust_pkg);
107   foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
108     my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
109     my($acct_svcpart);
110     foreach $acct_svcpart (@u_acct_svcparts) {   #now find the corresponding 
111                                               #record(s) in cust_svc ( for this
112                                               #pkgnum ! )
113       my($i_cust_svc);
114       foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) {
115         $svc_acct=qsearchs('svc_acct',{'svcnum'=>$i_cust_svc->getfield('svcnum')});
116         $email{$svc_acct->getfield('svcnum')}=$svc_acct->email;
117       }  
118     }
119   }
120
121 } elsif ( $action eq 'Edit' ) {
122
123   my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svc_forward->srcsvc});
124   $email{$svc_forward->srcsvc} = $svc_acct->email;
125
126   $svc_acct=qsearchs('svc_acct',{'svcnum'=>$svc_forward->dstsvc});
127   $email{$svc_forward->dstsvc} = $svc_acct->email;
128
129 } else {
130   die "\$action eq Add, but \$pkgnum is null!\n";
131 }
132
133 ($srcsvc,$dstsvc,$dst)=(
134   $svc_forward->srcsvc,
135   $svc_forward->dstsvc,
136   $svc_forward->dst,
137 );
138
139 #display
140
141 $p1 = popurl(1);
142 print $cgi->header( '-expires' => 'now' ), header("Mail Forward $action", '',
143       " onLoad=\"visualize()\"");
144
145 %>
146
147 <SCRIPT>
148 function visualize(what){
149     if (document.getElementById) {
150       document.getElementById('dother').style.visibility = '<%= $dstsvc ? 'hidden' : 'visible' %>';
151     }
152 }
153 function fixup(what){
154     if (document.getElementById) {
155       if (document.getElementById('dother').style.visibility == 'hidden') {
156         what.dst.value='';
157       }
158     }
159 }
160 </SCRIPT>
161
162 <%
163
164 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
165       "</FONT>"
166   if $cgi->param('error');
167
168 print qq!<FORM ACTION="${p1}process/svc_forward.cgi" onSubmit="fixup(this)" METHOD=POST>!;
169
170 #svcnum
171 print qq!<INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">!;
172 print qq!Service #<FONT SIZE=+1><B>!, $svcnum ? $svcnum : " (NEW)", "</B></FONT>";
173 print qq!<BR>!;
174
175 #pkgnum
176 print qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!;
177  
178 #svcpart
179 print qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!;
180
181 #srcsvc
182 print qq!\n\nMail to <SELECT NAME="srcsvc" SIZE=1>!;
183 foreach $_ (keys %email) {
184   print "<OPTION", $_ eq $srcsvc ? " SELECTED" : "",
185         qq! VALUE="$_">$email{$_}!;
186 }
187 print "</SELECT>";
188
189 #dstsvc
190 print qq! forwards to <SELECT NAME="dstsvc" SIZE=1 onChange="changed(this)">!;
191 foreach $_ (keys %email) {
192   print "<OPTION", $_ eq $dstsvc ? " SELECTED" : "",
193         qq! VALUE="$_">$email{$_}!;
194 }
195 print "<OPTION", 0 eq $dstsvc ? " SELECTED" : "",
196       qq! VALUE="0">(other)!;
197 print "</SELECT> mailbox.";
198
199 %>
200
201 <SCRIPT>
202 var selectchoice = null;
203 function changed(what) {
204   selectchoice = what.options[what.selectedIndex].value;
205   if (selectchoice == "0") {
206     if (document.getElementById) {
207       document.getElementById('dother').style.visibility = "visible";
208     }
209   }else{
210     if (document.getElementById) {
211       document.getElementById('dother').style.visibility = "hidden";
212     }
213   }
214 }
215 if (document.getElementById) {
216     document.write("<DIV ID=\"dother\" STYLE=\"visibility: hidden\">");
217 }
218 </SCRIPT>
219
220 <%
221 print qq! Other destination: <INPUT TYPE="text" NAME="dst" VALUE="$dst">!;
222 %>
223
224 <SCRIPT>
225 if (document.getElementById) {
226     document.write("</DIV>");
227 }
228 </SCRIPT>
229
230 <CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>
231 </FORM>
232
233 <TAG onLoad="
234     if (document.getElementById) {
235       document.getElementById('dother').style.visibility = '<%= $dstsvc ? 'hidden' : 'visible' %>';
236       document.getElementById('dlabel').style.visibility = '<%= $dstsvc ? 'hidden' : 'visible' %>';
237     }
238 ">
239
240
241   </BODY>
242 </HTML>