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