diff options
Diffstat (limited to 'httemplate/misc/process/link.cgi')
| -rwxr-xr-x | httemplate/misc/process/link.cgi | 40 | 
1 files changed, 40 insertions, 0 deletions
diff --git a/httemplate/misc/process/link.cgi b/httemplate/misc/process/link.cgi new file mode 100755 index 000000000..4b220a867 --- /dev/null +++ b/httemplate/misc/process/link.cgi @@ -0,0 +1,40 @@ +<% + +$cgi->param('pkgnum') =~ /^(\d+)$/; +my $pkgnum = $1; +$cgi->param('svcpart') =~ /^(\d+)$/; +my $svcpart = $1; +$cgi->param('svcnum') =~ /^(\d*)$/; +my $svcnum = $1; + +unless ( $svcnum ) { +  my($part_svc) = qsearchs('part_svc',{'svcpart'=>$svcpart}); +  my($svcdb) = $part_svc->getfield('svcdb'); +  $cgi->param('link_field') =~ /^(\w+)$/; my($link_field)=$1; +  my($svc_x)=qsearchs($svcdb,{$link_field => $cgi->param('link_value') }); +  eidiot("$link_field not found!") unless $svc_x; +  $svcnum=$svc_x->svcnum; +} + +my $old = qsearchs('cust_svc',{'svcnum'=>$svcnum}); +die "svcnum not found!" unless $old; +#die "svcnum $svcnum already linked to package ". $old->pkgnum if $old->pkgnum; +my $new = new FS::cust_svc ({ +  'svcnum' => $svcnum, +  'pkgnum' => $pkgnum, +  'svcpart' => $svcpart, +}); + +my $error = $new->replace($old); + +unless ($error) { +  #no errors, so let's view this customer. +  print $cgi->redirect(popurl(3). "view/cust_pkg.cgi?$pkgnum"); +} else { +%> +<!-- mason kludge --> +<% +  idiot($error); +} + +%>  | 
