2 # <!-- $Id: svc_forward.cgi,v 1.4 2001-09-11 23:44:01 ivan Exp $ -->
5 use vars qw( $conf $cgi $mydomain $action $svcnum $svc_forward $pkgnum $svcpart
6 $part_svc $query %email $p1 $srcsvc $dstsvc $dst );
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);
19 $mydomain = $conf->config('domain');
21 if ( $cgi->param('error') ) {
22 $svc_forward = new FS::svc_forward ( {
23 map { $_, scalar($cgi->param($_)) } fields('svc_forward')
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;
31 my($query) = $cgi->keywords;
32 if ( $query =~ /^(\d+)$/ ) { #editing
34 $svc_forward=qsearchs('svc_forward',{'svcnum'=>$svcnum})
35 or die "Unknown (svc_forward) svcnum!";
37 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
38 or die "Unknown (cust_svc) svcnum!";
40 $pkgnum=$cust_svc->pkgnum;
41 $svcpart=$cust_svc->svcpart;
43 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
44 die "No part_svc entry!" unless $part_svc;
48 $svc_forward = new FS::svc_forward({});
50 foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart
51 $pkgnum=$1 if /^pkgnum(\d+)$/;
52 $svcpart=$1 if /^svcpart(\d+)$/;
54 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
55 die "No part_svc entry!" unless $part_svc;
59 #set fixed and default fields from part_svc
60 foreach my $part_svc_column (
61 grep { $_->columnflag } $part_svc->all_part_svc_column
63 $svc_forward->setfield( $part_svc_column->columnname,
64 $part_svc_column->columnvalue,
71 $action = $svc_forward->svcnum ? 'Edit' : 'Add';
75 #find all possible user svcnums (and emails)
77 #starting with those currently attached
78 if ( $svc_forward->srcsvc ) {
79 my $svc_acct = qsearchs( 'svc_acct', { 'svcnum' => $svc_forward->srcsvc } );
80 $email{$svc_forward->srcsvc} = $svc_acct->email;
82 if ( $svc_forward->dstsvc ) {
83 my $svc_acct = qsearchs( 'svc_acct', { 'svcnum' => $svc_forward->dstsvc } );
84 $email{$svc_forward->dstsvc} = $svc_acct->email;
87 #and including the rest for this customer
88 my($u_part_svc,@u_acct_svcparts);
89 foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
90 push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
93 my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
94 my($custnum)=$cust_pkg->getfield('custnum');
96 foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
97 my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
99 foreach $acct_svcpart (@u_acct_svcparts) { #now find the corresponding
100 #record(s) in cust_svc ( for this
103 foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) {
104 $svc_acct=qsearchs('svc_acct',{'svcnum'=>$i_cust_svc->getfield('svcnum')});
105 $email{$svc_acct->getfield('svcnum')}=$svc_acct->email;
110 } elsif ( $action eq 'Edit' ) {
112 my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svc_forward->srcsvc});
113 $email{$svc_forward->srcsvc} = $svc_acct->email;
115 $svc_acct=qsearchs('svc_acct',{'svcnum'=>$svc_forward->dstsvc});
116 $email{$svc_forward->dstsvc} = $svc_acct->email;
119 die "\$action eq Add, but \$pkgnum is null!\n";
122 ($srcsvc,$dstsvc,$dst)=(
123 $svc_forward->srcsvc,
124 $svc_forward->dstsvc,
131 print $cgi->header( '-expires' => 'now' ), header("Mail Forward $action", '',
132 " onLoad=\"visualize()\"");
137 function visualize(what){
138 if (document.getElementById) {
139 document.getElementById('dother').style.visibility = '<%= $dstsvc ? 'hidden' : 'visible' %>';
142 function fixup(what){
143 if (document.getElementById) {
144 if (document.getElementById('dother').style.visibility == 'hidden') {
153 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
155 if $cgi->param('error');
157 print qq!<FORM ACTION="${p1}process/svc_forward.cgi" onSubmit="fixup(this)" METHOD=POST>!;
160 print qq!<INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">!;
161 print qq!Service #<FONT SIZE=+1><B>!, $svcnum ? $svcnum : " (NEW)", "</B></FONT>";
165 print qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!;
168 print qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!;
171 print qq!\n\nMail to <SELECT NAME="srcsvc" SIZE=1>!;
172 foreach $_ (keys %email) {
173 print "<OPTION", $_ eq $srcsvc ? " SELECTED" : "",
174 qq! VALUE="$_">$email{$_}!;
179 print qq! forwards to <SELECT NAME="dstsvc" SIZE=1 onChange="changed(this)">!;
180 foreach $_ (keys %email) {
181 print "<OPTION", $_ eq $dstsvc ? " SELECTED" : "",
182 qq! VALUE="$_">$email{$_}!;
184 print "<OPTION", 0 eq $dstsvc ? " SELECTED" : "",
185 qq! VALUE="0">(other)!;
186 print "</SELECT> mailbox.";
191 var selectchoice = null;
192 function changed(what) {
193 selectchoice = what.options[what.selectedIndex].value;
194 if (selectchoice == "0") {
195 if (document.getElementById) {
196 document.getElementById('dother').style.visibility = "visible";
199 if (document.getElementById) {
200 document.getElementById('dother').style.visibility = "hidden";
204 if (document.getElementById) {
205 document.write("<DIV ID=\"dother\" STYLE=\"visibility: hidden\">");
210 print qq! Other destination: <INPUT TYPE="text" NAME="dst" VALUE="$dst">!;
214 if (document.getElementById) {
215 document.write("</DIV>");
219 <CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>
223 if (document.getElementById) {
224 document.getElementById('dother').style.visibility = '<%= $dstsvc ? 'hidden' : 'visible' %>';
225 document.getElementById('dlabel').style.visibility = '<%= $dstsvc ? 'hidden' : 'visible' %>';