diff options
Diffstat (limited to 'httemplate/misc')
32 files changed, 1203 insertions, 0 deletions
| diff --git a/httemplate/misc/bill.cgi b/httemplate/misc/bill.cgi new file mode 100755 index 000000000..44d85b880 --- /dev/null +++ b/httemplate/misc/bill.cgi @@ -0,0 +1,38 @@ +<% + +#untaint custnum +my($query) = $cgi->keywords; +$query =~ /^(\d*)$/; +my $custnum = $1; +my $cust_main = qsearchs('cust_main',{'custnum'=>$custnum}); +die "Can't find customer!\n" unless $cust_main; + +my $error = $cust_main->bill( +#                          'time'=>$time +                         ); +#&eidiot($error) if $error; + +unless ( $error ) { +  $cust_main->apply_payments; +  $cust_main->apply_credits; + +  $error = $cust_main->collect( +  #                             'invoice-time'=>$time, +                               #'batch_card'=> 'yes', +                               #'batch_card'=> 'no', +                               #'report_badcard'=> 'yes', +                               #'retry_card' => 'yes', +                               'retry' => 'yes', +                              ); +} +#&eidiot($error) if $error; + +if ( $error ) { +%> +<!-- mason kludge --> +<% +  &idiot($error); +} else { +  print $cgi->redirect(popurl(2). "view/cust_main.cgi?$custnum"); +} +%> diff --git a/httemplate/misc/cancel-unaudited.cgi b/httemplate/misc/cancel-unaudited.cgi new file mode 100755 index 000000000..11cde968d --- /dev/null +++ b/httemplate/misc/cancel-unaudited.cgi @@ -0,0 +1,31 @@ +<% + +my $dbh = dbh; +  +#untaint svcnum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/; +my $svcnum = $1; + +#my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$svcnum}); +#die "Unknown svcnum!" unless $svc_acct; + +my $cust_svc = qsearchs('cust_svc',{'svcnum'=>$svcnum}); +die "Unknown svcnum!" unless $cust_svc; +&eidiot(qq!This account has already been audited.  Cancel the  +    <A HREF="!. popurl(2). qq!view/cust_pkg.cgi?! . $cust_svc->getfield('pkgnum') . +    qq!pkgnum"> package</A> instead.!)  +  if $cust_svc->pkgnum ne '' && $cust_svc->pkgnum ne '0'; + +my $error = $cust_svc->cancel; + +if ( $error ) { +  %> +<!-- mason kludge --> +<% +  &eidiot($error); +} else { +  print $cgi->redirect(popurl(2)); +} + +%> diff --git a/httemplate/misc/cancel_pkg.cgi b/httemplate/misc/cancel_pkg.cgi new file mode 100755 index 000000000..0487677df --- /dev/null +++ b/httemplate/misc/cancel_pkg.cgi @@ -0,0 +1,15 @@ +<% + +#untaint pkgnum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal pkgnum"; +my $pkgnum = $1; + +my $cust_pkg = qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); + +my $error = $cust_pkg->cancel; +eidiot($error) if $error; + +print $cgi->redirect($p. "view/cust_main.cgi?".$cust_pkg->getfield('custnum')); + +%> diff --git a/httemplate/misc/catchall.cgi b/httemplate/misc/catchall.cgi new file mode 100755 index 000000000..3402b61e6 --- /dev/null +++ b/httemplate/misc/catchall.cgi @@ -0,0 +1,133 @@ +<!-- mason kludge --> +<% + +my $conf = new FS::Conf; + +my($svc_domain, $svcnum, $pkgnum, $svcpart, $part_svc); +if ( $cgi->param('error') ) { +  $svc_domain = new FS::svc_domain ( { +    map { $_, scalar($cgi->param($_)) } fields('svc_domain') +  } ); +  $svcnum = $svc_domain->svcnum; +  $pkgnum = $cgi->param('pkgnum'); +  $svcpart = $cgi->param('svcpart'); +  $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart}); +  die "No part_svc entry!" unless $part_svc; +} else { +  my($query) = $cgi->keywords; +  if ( $query =~ /^(\d+)$/ ) { #editing +    $svcnum=$1; +    $svc_domain=qsearchs('svc_domain',{'svcnum'=>$svcnum}) +      or die "Unknown (svc_domain) svcnum!"; + +    my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum}) +      or die "Unknown (cust_svc) svcnum!"; + +    $pkgnum=$cust_svc->pkgnum; +    $svcpart=$cust_svc->svcpart; +   +    $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart}); +    die "No part_svc entry!" unless $part_svc; + +  } else {  + +    die "Invalid (svc_domain) svcnum!"; + +  } +} + +my %email; +if ($pkgnum) { + +  #find all possible user svcnums (and emails) + +  #starting with that currently attached +  if ($svc_domain->catchall) { +    my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svc_domain->catchall}); +    $email{$svc_domain->catchall} = $svc_acct->email; +  } + +  #and including the rest for this customer +  my($u_part_svc,@u_acct_svcparts); +  foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) { +    push @u_acct_svcparts,$u_part_svc->getfield('svcpart'); +  } + +  my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); +  my($custnum)=$cust_pkg->getfield('custnum'); +  my($i_cust_pkg); +  foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) { +    my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum'); +    my($acct_svcpart); +    foreach $acct_svcpart (@u_acct_svcparts) {   #now find the corresponding  +                                              #record(s) in cust_svc ( for this +                                              #pkgnum ! ) +      my($i_cust_svc); +      foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) { +        my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$i_cust_svc->getfield('svcnum')}); +        $email{$svc_acct->getfield('svcnum')}=$svc_acct->email; +      }   +    } +  } + +} else { + +  my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svc_domain->catchall}); +  $email{$svc_domain->catchall} = $svc_acct->email; +} + +# add an absence of a catchall +$email{''} = "(none)"; + +my $p1 = popurl(1); +print header("Domain Catchall Edit", ''); + +print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'), +      "</FONT>" +  if $cgi->param('error'); + +print qq!<FORM ACTION="${p1}process/catchall.cgi" METHOD=POST>!; + +#display + +	#formatting +	print "<PRE>"; + +#svcnum +print qq!<INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">!; +print qq!Service #<FONT SIZE=+1><B>!, $svcnum ? $svcnum : " (NEW)", "</B></FONT>"; + +#pkgnum +print qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!; +  +#svcpart +print qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!; + +my($domain,$catchall)=( +  $svc_domain->domain, +  $svc_domain->catchall, +); + +print qq!<INPUT TYPE="hidden" NAME="domain" VALUE="$domain">!; + +#catchall +print qq!\n\nMail to <I>(anything)</I>@<B>$domain</B> forwards to <SELECT NAME="catchall" SIZE=1>!; +foreach $_ (keys %email) { +  print "<OPTION", $_ eq $catchall ? " SELECTED" : "", +        qq! VALUE="$_">$email{$_}!; +} +print "</SELECT>"; + +	#formatting +	print "</PRE>\n"; + +print qq!<CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>!; + +print <<END; + +    </FORM> +  </BODY> +</HTML> +END + +%> diff --git a/httemplate/misc/change_pkg.cgi b/httemplate/misc/change_pkg.cgi new file mode 100755 index 000000000..5346fd9d8 --- /dev/null +++ b/httemplate/misc/change_pkg.cgi @@ -0,0 +1,66 @@ +<!-- mason kludge --> +<% + +my $pkgnum; +if ( $cgi->param('error') ) { +  #$custnum = $cgi->param('custnum'); +  #%remove_pkg = map { $_ => 1 } $cgi->param('remove_pkg'); +  $pkgnum = ($cgi->param('remove_pkg'))[0]; +} else { +  my($query) = $cgi->keywords; +  $query =~ /^(\d+)$/; +  #$custnum = $1; +  $pkgnum = $1; +  #%remove_pkg = (); +} + +my $cust_pkg = qsearchs( 'cust_pkg', { 'pkgnum' => $pkgnum } ) +  or die "unknown pkgnum $pkgnum"; +my $custnum = $cust_pkg->custnum; + +my $conf = new FS::Conf; + +my $p1 = popurl(1); + +my $cust_main = $cust_pkg->cust_main +  or die "can't get cust_main record for custnum ". $cust_pkg->custnum. +         " ( pkgnum ". cust_pkg->pkgnum. ")"; +my $agent = $cust_main->agent; + +print header("Change Package",  menubar( +  "View this customer (#$custnum)" => "${p}view/cust_main.cgi?$custnum", +  'Main Menu' => $p, +)); + +print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'), +      "</FONT><BR><BR>" +  if $cgi->param('error'); + +my $part_pkg = $cust_pkg->part_pkg; + +print small_custview( $cust_main, $conf->config('countrydefault') ). +      qq!<FORM ACTION="${p}edit/process/cust_pkg.cgi" METHOD=POST>!. +      qq!<INPUT TYPE="hidden" NAME="custnum" VALUE="$custnum">!. +      qq!<INPUT TYPE="hidden" NAME="remove_pkg" VALUE="$pkgnum">!. +      '<BR>Current package: '. $part_pkg->pkg. ' - '. $part_pkg->comment. +      qq!<BR>New package: <SELECT NAME="new_pkgpart"><OPTION VALUE=0></OPTION>!; + +foreach my $part_pkg ( +  grep { ! $_->disabled && $_->pkgpart != $cust_pkg->pkgpart } +    map { $_->part_pkg } $agent->agent_type->type_pkgs +) { +  my $pkgpart = $part_pkg->pkgpart; +  print qq!<OPTION VALUE="$pkgpart"!; +  print ' SELECTED' if $cgi->param('error') +                       && $cgi->param('new_pkgpart') == $pkgpart; +  print qq!>$pkgpart: !. $part_pkg->pkg. ' - '. $part_pkg->comment. '</OPTION>'; +} + +print <<END; +</SELECT> +<BR><BR><INPUT TYPE="submit" VALUE="Change package"> +    </FORM> +  </BODY> +</HTML> +END +%> diff --git a/httemplate/misc/cust_main-cancel.cgi b/httemplate/misc/cust_main-cancel.cgi new file mode 100755 index 000000000..257c3384f --- /dev/null +++ b/httemplate/misc/cust_main-cancel.cgi @@ -0,0 +1,16 @@ +<% + +#untaint custnum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal custnum"; +my $custnum = $1; + +my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } ); + +my @errors = $cust_main->cancel; +eidiot(join(' / ', @errors)) if scalar(@errors); + +#print $cgi->redirect($p. "view/cust_main.cgi?". $cust_main->custnum); +print $cgi->redirect($p); + +%> diff --git a/httemplate/misc/cust_main-import.cgi b/httemplate/misc/cust_main-import.cgi new file mode 100644 index 000000000..6b36f478d --- /dev/null +++ b/httemplate/misc/cust_main-import.cgi @@ -0,0 +1,51 @@ +<!-- mason kludge --> +<%= header('Batch Customer Import') %> +<FORM ACTION="process/cust_main-import.cgi" METHOD="post" ENCTYPE="multipart/form-data"> +Import a CSV file containing customer records.<BR><BR> +Default file format is CSV, with the following field order: <i>cust_pkg.setup, dayphone, first, last, address1, address2, city, state, zip, comments</i><BR><BR> + +<% +  #false laziness with edit/cust_main.cgi +  my @agents = qsearch( 'agent', {} ); +  die "No agents created!" unless @agents; +  my $agentnum = $agents[0]->agentnum; #default to first + +  if ( scalar(@agents) == 1 ) { +%> +    <INPUT TYPE="hidden" NAME="agentnum" VALUE="<%= $agentnum %>"> +<% } else { %> +    <BR><BR>Agent <SELECT NAME="agentnum" SIZE="1"> +  <% foreach my $agent (sort { $a->agent cmp $b->agent } @agents) { %> +    <OPTION VALUE="<%= $agent->agentnum %>" <%= " SELECTED"x($agent->agentnum==$agentnum) %>><%= $agent->agent %></OPTION> +  <% } %> +    </SELECT><BR><BR> +<% } %> + +<% +  my @referrals = qsearch('part_referral',{}); +  die "No advertising sources created!" unless @referrals; +  my $refnum = $referrals[0]->refnum; #default to first + +  if ( scalar(@referrals) == 1 ) { +%> +    <INPUT TYPE="hidden" NAME="refnum" VALUE="<%= $refnum %>"> +<% } else { %> +    <BR><BR>Advertising source <SELECT NAME="refnum" SIZE="1"> +  <% foreach my $referral ( sort { $a->referral <=> $b->referral } @referrals) { %> +    <OPTION VALUE="<%= $referral->refnum %>" <%= " SELECTED"x($referral->refnum==$refnum) %>><%= $referral->refnum %>: <%= $referral->referral %></OPTION> +  <% } %> +    </SELECT><BR><BR> +<% } %> + +    First package: <SELECT NAME="pkgpart"><OPTION VALUE="">(none)</OPTION> +<% foreach my $part_pkg ( qsearch('part_pkg',{'disabled'=>'' }) ) { %> +     <OPTION VALUE="<%= $part_pkg->pkgpart %>"><%= $part_pkg->pkg. ' - '. $part_pkg->comment %></OPTION> +<% } %> +</SELECT><BR><BR> + +    CSV Filename: <INPUT TYPE="file" NAME="csvfile"><BR><BR> +    <INPUT TYPE="submit" VALUE="Import"> +    </FORM> +  </BODY> +<HTML> + diff --git a/httemplate/misc/cust_main-import_charges.cgi b/httemplate/misc/cust_main-import_charges.cgi new file mode 100644 index 000000000..0822b9eb6 --- /dev/null +++ b/httemplate/misc/cust_main-import_charges.cgi @@ -0,0 +1,14 @@ +<!-- mason kludge --> +<%= header('Batch Customer Charge') %> +<FORM ACTION="process/cust_main-import_charges.cgi" METHOD="post" ENCTYPE="multipart/form-data"> +Import a CSV file containing customer charges.<BR><BR> +Default file format is CSV, with the following field order: <i>custnum, amount, description</i><BR><BR> +If <i>amount</i> is negative, a credit will be applied instead.<BR><BR> +<BR><BR> + +    CSV Filename: <INPUT TYPE="file" NAME="csvfile"><BR><BR> +    <INPUT TYPE="submit" VALUE="Import"> +    </FORM> +  </BODY> +<HTML> + diff --git a/httemplate/misc/delete-cust_credit.cgi b/httemplate/misc/delete-cust_credit.cgi new file mode 100755 index 000000000..30de04d27 --- /dev/null +++ b/httemplate/misc/delete-cust_credit.cgi @@ -0,0 +1,16 @@ +<% + +#untaint crednum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal crednum"; +my $crednum = $1; + +my $cust_credit = qsearchs('cust_credit',{'crednum'=>$crednum}); +my $custnum = $cust_credit->custnum; + +my $error = $cust_credit->delete; +eidiot($error) if $error; + +print $cgi->redirect($p. "view/cust_main.cgi?". $custnum); + +%> diff --git a/httemplate/misc/delete-cust_pay.cgi b/httemplate/misc/delete-cust_pay.cgi new file mode 100755 index 000000000..3efd918ab --- /dev/null +++ b/httemplate/misc/delete-cust_pay.cgi @@ -0,0 +1,16 @@ +<% + +#untaint paynum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal paynum"; +my $paynum = $1; + +my $cust_pay = qsearchs('cust_pay',{'paynum'=>$paynum}); +my $custnum = $cust_pay->custnum; + +my $error = $cust_pay->delete; +eidiot($error) if $error; + +print $cgi->redirect($p. "view/cust_main.cgi?". $custnum); + +%> diff --git a/httemplate/misc/delete-customer.cgi b/httemplate/misc/delete-customer.cgi new file mode 100755 index 000000000..430231737 --- /dev/null +++ b/httemplate/misc/delete-customer.cgi @@ -0,0 +1,60 @@ +<!-- mason kludge --> +<% + +my $conf = new FS::Conf; +die "Customer deletions not enabled" unless $conf->exists('deletecustomers'); + +my($custnum, $new_custnum); +if ( $cgi->param('error') ) { +  $custnum = $cgi->param('custnum'); +  $new_custnum = $cgi->param('new_custnum'); +} else { +  my($query) = $cgi->keywords; +  $query =~ /^(\d+)$/ or die "Illegal query: $query"; +  $custnum = $1; +  $new_custnum = ''; +} +my $cust_main = qsearchs( 'cust_main', { 'custnum' => $custnum } ) +  or die "Customer not found: $custnum"; + +print header('Delete customer'); + +print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'), +      "</FONT>" +  if $cgi->param('error'); + +print  +  qq!<form action="!, popurl(1), qq!process/delete-customer.cgi" method=post>!, +  qq!<input type="hidden" name="custnum" value="$custnum">!; + +if ( qsearch('cust_pkg', { 'custnum' => $custnum, 'cancel' => '' } ) ) { +  print "Move uncancelled packages to customer number ", +        qq!<input type="text" name="new_custnum" value="$new_custnum"><br><br>!; +} + +print <<END; +This will <b>completely remove</b> all traces of this customer record.  This +is <B>not</B> what you want if this is a real customer who has simply +canceled service with you.  For that, cancel all of the customer's packages. +(you can optionally hide cancelled customers with the <a href="../config/config-view.cgi#hidecancelledcustomers">hidecancelledcustomers</a> configuration option) +<br> +<br>Are you <b>absolutely sure</b> you want to delete this customer? +<br><input type="submit" value="Yes"> +</form></body></html> +END + +#Deleting a customer you have financial records on (i.e. credits) is +#typically considered fraudulant bookkeeping.  Remember, deleting    +#customers should ONLY be used for completely bogus records.  You should +#NOT delete real customers who simply discontinue service. +# +#For real customers who simply discontinue service, cancel all of the +#customer's packages.  Customers with all cancelled packages are not   +#billed.  There is no need to take further action to prevent billing on +#customers with all cancelled packages. +# +#Also see the "hidecancelledcustomers" and "hidecancelledpackages" +#configuration options, which will allow you to surpress the display of +#cancelled customers and packages, respectively. + +%> diff --git a/httemplate/misc/delete-domain_record.cgi b/httemplate/misc/delete-domain_record.cgi new file mode 100755 index 000000000..dcc2d5022 --- /dev/null +++ b/httemplate/misc/delete-domain_record.cgi @@ -0,0 +1,15 @@ +<% + +#untaint recnum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal recnum"; +my $recnum = $1; + +my $domain_record = qsearchs('domain_record',{'recnum'=>$recnum}); + +my $error = $domain_record->delete; +eidiot($error) if $error; + +print $cgi->redirect($p. "view/svc_domain.cgi?". $domain_record->svcnum); + +%> diff --git a/httemplate/misc/delete-part_export.cgi b/httemplate/misc/delete-part_export.cgi new file mode 100755 index 000000000..7c4ab8b9d --- /dev/null +++ b/httemplate/misc/delete-part_export.cgi @@ -0,0 +1,15 @@ +<% + +#untaint exportnum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal exportnum"; +my $exportnum = $1; + +my $part_export = qsearchs('part_export',{'exportnum'=>$exportnum}); + +my $error = $part_export->delete; +eidiot($error) if $error; + +print $cgi->redirect($p. "browse/part_export.cgi"); + +%> diff --git a/httemplate/misc/download-batch.cgi b/httemplate/misc/download-batch.cgi new file mode 100644 index 000000000..306ef5d63 --- /dev/null +++ b/httemplate/misc/download-batch.cgi @@ -0,0 +1,16 @@ +<% + +#http_header('Content-Type' => 'text/comma-separated-values' ); #IE chokes +http_header('Content-Type' => 'text/plain' ); + +for my $cust_pay_batch ( sort { $a->paybatchnum <=> $b->paybatchnum } +                              qsearch('cust_pay_batch', {} ) +) { + +$cust_pay_batch->exp =~ /^\d{2}(\d{2})[\/\-](\d+)[\/\-]\d+$/; +my( $mon, $y ) = ( $2, $1 ); +$mon = "0$mon" if $mon < 10; +my $exp = "$mon$y"; + +%>,,,,<%= $cust_pay_batch->cardnum %>,<%= $exp %>,<%= $cust_pay_batch->amount %>,<%= $cust_pay_batch->paybatchnum %> +<% } %> diff --git a/httemplate/misc/dump.cgi b/httemplate/misc/dump.cgi new file mode 100644 index 000000000..dc1323bb3 --- /dev/null +++ b/httemplate/misc/dump.cgi @@ -0,0 +1,19 @@ +<% +  if ( driver_name =~ /^Pg$/ ) { +    my $dbname = (split(':', datasrc))[2]; +    if ( $dbname =~ /[;=]/ ) { +      my %elements = map { /^(\w+)=(.*)$/; $1=>$2 } split(';', $dbname); +      $dbname = $elements{'dbname'}; +    } +    open(DUMP,"pg_dump $dbname |"); +  } else { +    eidiot "don't (yet) know how to dump ". driver_name. " databases\n"; +  } + +  http_header('Content-Type' => 'text/plain' ); + +  while (<DUMP>) { +    print $_; +  } +  close DUMP; +%> diff --git a/httemplate/misc/email-invoice.cgi b/httemplate/misc/email-invoice.cgi new file mode 100755 index 000000000..7ab1613ee --- /dev/null +++ b/httemplate/misc/email-invoice.cgi @@ -0,0 +1,23 @@ +<% + +my $conf = new FS::Conf; + +#untaint invnum +my($query) = $cgi->keywords; +$query =~ /^(\d*)$/; +my $invnum = $1; +my $cust_bill = qsearchs('cust_bill',{'invnum'=>$invnum}); +die "Can't find invoice!\n" unless $cust_bill; + +my $error = send_email( +  'from'    => $conf->config('invoice_from'), +  'to'      => [ grep { $_ ne 'POST' } $cust_bill->cust_main->invoicing_list ], +  'subject' => 'Invoice', +  'body'    => [ $cust_bill->print_text ], +); +eidiot($error) if $error; + +my $custnum = $cust_bill->getfield('custnum'); +print $cgi->redirect("${p}view/cust_main.cgi?$custnum"); + +%> diff --git a/httemplate/misc/expire_pkg.cgi b/httemplate/misc/expire_pkg.cgi new file mode 100755 index 000000000..9e4ce8b62 --- /dev/null +++ b/httemplate/misc/expire_pkg.cgi @@ -0,0 +1,25 @@ +<% + +#untaint date & pkgnum + +my $date; +if ( $cgi->param('date') ) { +  str2time($cgi->param('date')) =~ /^(\d+)$/ or die "Illegal date"; +  $date=$1; +} else { +  $date=''; +} + +$cgi->param('pkgnum') =~ /^(\d+)$/ or die "Illegal pkgnum"; +my $pkgnum = $1; + +my $cust_pkg = qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); +my %hash = $cust_pkg->hash; +$hash{expire}=$date; +my $new = new FS::cust_pkg ( \%hash ); +my $error = $new->replace($cust_pkg); +&eidiot($error) if $error; + +print $cgi->redirect(popurl(2). "view/cust_main.cgi?".$cust_pkg->getfield('custnum')); + +%> diff --git a/httemplate/misc/link.cgi b/httemplate/misc/link.cgi new file mode 100755 index 000000000..79adce88c --- /dev/null +++ b/httemplate/misc/link.cgi @@ -0,0 +1,45 @@ +<!-- mason kludge --> +<% + +my %link_field = ( +  'svc_acct'    => 'username', +  'svc_domain'  => 'domain', +  'svc_charge'  => '', +  'svc_wo'      => '', +); + +my($query) = $cgi->keywords; +my($pkgnum, $svcpart) = ('', ''); +foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart +  $pkgnum=$1 if /^pkgnum(\d+)$/; +  $svcpart=$1 if /^svcpart(\d+)$/; +} + +my $part_svc = qsearchs('part_svc',{'svcpart'=>$svcpart}); +my $svc = $part_svc->getfield('svc'); +my $svcdb = $part_svc->getfield('svcdb'); +my $link_field = $link_field{$svcdb}; + +print header("Link to existing $svc"), +      qq!<FORM ACTION="!, popurl(1), qq!process/link.cgi" METHOD=POST>!; + +if ( $link_field ) {  +  print <<END; +  <INPUT TYPE="hidden" NAME="svcnum" VALUE=""> +  <INPUT TYPE="hidden" NAME="link_field" VALUE="$link_field"> +  $link_field of existing service: <INPUT TYPE="text" NAME="link_value"> +END +} else { +  print qq!Service # of existing service: <INPUT TYPE="text" NAME="svcnum" VALUE="">!; +} + +print <<END; +<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum"> +<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart"> +<P><CENTER><INPUT TYPE="submit" VALUE="Link"></CENTER> +    </FORM> +  </BODY> +</HTML> +END + +%> diff --git a/httemplate/misc/meta-import.cgi b/httemplate/misc/meta-import.cgi new file mode 100644 index 000000000..2f3b7380d --- /dev/null +++ b/httemplate/misc/meta-import.cgi @@ -0,0 +1,64 @@ +<!-- mason kludge --> +<%= header('Import') %> +<FORM ACTION="process/meta-import.cgi" METHOD="post" ENCTYPE="multipart/form-data"> +Import data from a DBI data source<BR><BR> + +<% +  #false laziness with edit/cust_main.cgi +  my @agents = qsearch( 'agent', {} ); +  die "No agents created!" unless @agents; +  my $agentnum = $agents[0]->agentnum; #default to first + +  if ( scalar(@agents) == 1 ) { +%> +    <INPUT TYPE="hidden" NAME="agentnum" VALUE="<%= $agentnum %>"> +<% } else { %> +    <BR><BR>Agent <SELECT NAME="agentnum" SIZE="1"> +  <% foreach my $agent (sort { $a->agent cmp $b->agent } @agents) { %> +    <OPTION VALUE="<%= $agent->agentnum %>" <%= " SELECTED"x($agent->agentnum==$agentnum) %>><%= $agent->agent %></OPTION> +  <% } %> +    </SELECT><BR><BR> +<% } %> + +<% +  my @referrals = qsearch('part_referral',{}); +  die "No advertising sources created!" unless @referrals; +  my $refnum = $referrals[0]->refnum; #default to first + +  if ( scalar(@referrals) == 1 ) { +%> +    <INPUT TYPE="hidden" NAME="refnum" VALUE="<%= $refnum %>"> +<% } else { %> +    <BR><BR>Advertising source <SELECT NAME="refnum" SIZE="1"> +  <% foreach my $referral ( sort { $a->referral <=> $b->referral } @referrals) { %> +    <OPTION VALUE="<%= $referral->refnum %>" <%= " SELECTED"x($referral->refnum==$refnum) %>><%= $referral->refnum %>: <%= $referral->referral %></OPTION> +  <% } %> +    </SELECT><BR><BR> +<% } %> + +    First package: <SELECT NAME="pkgpart"><OPTION VALUE="">(none)</OPTION> +<% foreach my $part_pkg ( qsearch('part_pkg',{'disabled'=>'' }) ) { %> +     <OPTION VALUE="<%= $part_pkg->pkgpart %>"><%= $part_pkg->pkg. ' - '. $part_pkg->comment %></OPTION> +<% } %> +</SELECT><BR><BR> + +  <table> +    <tr> +      <td align="right">DBI data source: </td> +      <td><INPUT TYPE="text" NAME="data_source"></td> +    </tr> +    <tr> +      <td align="right">DBI username: </td> +      <td><INPUT TYPE="text" NAME="username"></td> +    </tr> +    <tr> +      <td align="right">DBI password: </td> +      <td><INPUT TYPE="text" NAME="password"></td> +    </tr> +  </table> +  <INPUT TYPE="submit" VALUE="Import"> + +  </FORM> +  </BODY> +<HTML> + diff --git a/httemplate/misc/print-invoice.cgi b/httemplate/misc/print-invoice.cgi new file mode 100755 index 000000000..144f6156a --- /dev/null +++ b/httemplate/misc/print-invoice.cgi @@ -0,0 +1,29 @@ +<% + +my $conf = new FS::Conf; +my $lpr = $conf->config('lpr'); + +#untaint invnum +my($query) = $cgi->keywords; +$query =~ /^(\d*)$/; +my $invnum = $1; +my $cust_bill = qsearchs('cust_bill',{'invnum'=>$invnum}); +die "Can't find invoice!\n" unless $cust_bill; + +        open(LPR,"|$lpr") or die "Can't open $lpr: $!"; + +        if ( $conf->exists('invoice_latex') ) { +          print LPR $cust_bill->print_ps; #( date ) +        } else { +          print LPR $cust_bill->print_text; #( date ) +        } + +        close LPR +          or die $! ? "Error closing $lpr: $!" +                       : "Exit status $? from $lpr"; + +my $custnum = $cust_bill->getfield('custnum'); + +print $cgi->redirect("${p}view/cust_main.cgi?$custnum"); + +%> diff --git a/httemplate/misc/process/catchall.cgi b/httemplate/misc/process/catchall.cgi new file mode 100755 index 000000000..44a63f9f8 --- /dev/null +++ b/httemplate/misc/process/catchall.cgi @@ -0,0 +1,33 @@ +<% + +$FS::svc_domain::whois_hack=1; + +$cgi->param('svcnum') =~ /^(\d*)$/ or die "Illegal svcnum!"; +my $svcnum =$1; + +my $old = qsearchs('svc_domain',{'svcnum'=>$svcnum}) if $svcnum; + +my $new = new FS::svc_domain ( { +  map { +    ($_, scalar($cgi->param($_))); +  } ( fields('svc_domain'), qw( pkgnum svcpart ) ) +} ); + +$new->setfield('action' => 'M'); + +my $error; +if ( $svcnum ) { +  $error = $new->replace($old); +} else { +  $error = $new->insert; +  $svcnum = $new->getfield('svcnum'); +}  + +if ($error) { +  $cgi->param('error', $error); +  print $cgi->redirect(popurl(2). "catchall.cgi?". $cgi->query_string ); +} else { +  print $cgi->redirect(popurl(3). "view/svc_domain.cgi?$svcnum"); +} + +%> diff --git a/httemplate/misc/process/cust_main-import.cgi b/httemplate/misc/process/cust_main-import.cgi new file mode 100644 index 000000000..9e1adce54 --- /dev/null +++ b/httemplate/misc/process/cust_main-import.cgi @@ -0,0 +1,30 @@ +<% + +  my $fh = $cgi->upload('csvfile'); +  #warn $cgi; +  #warn $fh; + +  my $error = defined($fh) +    ? FS::cust_main::batch_import( { +        filehandle => $fh, +        agentnum   => scalar($cgi->param('agentnum')), +        refnum     => scalar($cgi->param('refnum')), +        pkgpart    => scalar($cgi->param('pkgpart')), +        'fields'    => [qw( cust_pkg.setup dayphone first last address1 address2 +                           city state zip comments                          )], +      } ) +    : 'No file'; + +  if ( $error ) { +    %> +    <!-- mason kludge --> +    <% +    eidiot($error); +#    $cgi->param('error', $error); +#    print $cgi->redirect( "${p}cust_main-import.cgi +  } else { +    %> +    <!-- mason kludge --> +    <%= header('Import sucessful') %> <% +  } +%> diff --git a/httemplate/misc/process/cust_main-import_charges.cgi b/httemplate/misc/process/cust_main-import_charges.cgi new file mode 100644 index 000000000..14df1bd8d --- /dev/null +++ b/httemplate/misc/process/cust_main-import_charges.cgi @@ -0,0 +1,26 @@ +<% + +  my $fh = $cgi->upload('csvfile'); +  #warn $cgi; +  #warn $fh; + +  my $error = defined($fh) +    ? FS::cust_main::batch_charge( { +        filehandle => $fh, +        'fields'    => [qw( custnum amount pkg )], +      } ) +    : 'No file'; + +  if ( $error ) { +    %> +    <!-- mason kludge --> +    <% +    eidiot($error); +#    $cgi->param('error', $error); +#    print $cgi->redirect( "${p}cust_main-import_charges.cgi +  } else { +    %> +    <!-- mason kludge --> +    <%= header('Import sucessful') %> <% +  } +%> diff --git a/httemplate/misc/process/delete-customer.cgi b/httemplate/misc/process/delete-customer.cgi new file mode 100755 index 000000000..16bdbaea8 --- /dev/null +++ b/httemplate/misc/process/delete-customer.cgi @@ -0,0 +1,29 @@ +<% + +my $conf = new FS::Conf; +die "Customer deletions not enabled" unless $conf->exists('deletecustomers'); + +$cgi->param('custnum') =~ /^(\d+)$/; +my $custnum = $1; +my $new_custnum; +if ( $cgi->param('new_custnum') ) { +  $cgi->param('new_custnum') =~ /^(\d+)$/ +    or die "Illegal new customer number: ". $cgi->param('new_custnum'); +  $new_custnum = $1; +} else { +  $new_custnum = ''; +} +my $cust_main = qsearchs( 'cust_main', { 'custnum' => $custnum } ) +  or die "Customer not found: $custnum"; + +my $error = $cust_main->delete($new_custnum); + +if ( $error ) { +  $cgi->param('error', $error); +  print $cgi->redirect(popurl(2). "delete-customer.cgi?". $cgi->query_string ); +} elsif ( $new_custnum ) { +  print $cgi->redirect(popurl(3). "view/cust_main.cgi?$new_custnum"); +} else { +  print $cgi->redirect(popurl(3)); +} +%> diff --git a/httemplate/misc/process/link.cgi b/httemplate/misc/process/link.cgi new file mode 100755 index 000000000..5d80adeb9 --- /dev/null +++ b/httemplate/misc/process/link.cgi @@ -0,0 +1,43 @@ +<% + +$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 = ( grep { $_->cust_svc->svcpart == $svcpart }  +                  qsearch( $svcdb, { $link_field => $cgi->param('link_value') }) +              )[0]; +  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); +} + +%> diff --git a/httemplate/misc/process/meta-import.cgi b/httemplate/misc/process/meta-import.cgi new file mode 100644 index 000000000..59d236f64 --- /dev/null +++ b/httemplate/misc/process/meta-import.cgi @@ -0,0 +1,178 @@ +<!-- mason kludge --> +<%= header('Map tables') %> + +<SCRIPT> +var gSafeOnload = new Array(); +var gSafeOnsubmit = new Array(); +window.onload = SafeOnload; +function SafeAddOnLoad(f) { +  gSafeOnload[gSafeOnload.length] = f; +} +function SafeOnload() { +  for (var i=0;i<gSafeOnload.length;i++) +    gSafeOnload[i](); +} +function SafeAddOnSubmit(f) { +  gSafeOnsubmit[gSafeOnsubmit.length] = f; +} +function SafeOnsubmit() { +  for (var i=0;i<gSafeOnsubmit.length;i++) +    gSafeOnsubmit[i](); +} +</SCRIPT> + +<FORM NAME="OneTrueForm" METHOD="POST" ACTION="meta-import.cgi"> + +<% +  #use DBIx::DBSchema; +  my $schema = new_native DBIx::DBSchema +                 map { $cgi->param($_) } qw( data_source username password ); +  foreach my $field (qw( data_source username password )) { %> +    <INPUT TYPE="hidden" NAME=<%= $field %> VALUE="<%= $cgi->param($field) %>"> +  <% } + +  my %schema; +  use Tie::DxHash; +  tie %schema, 'Tie::DxHash'; +  if ( $cgi->param('schema') ) { +    my $schema_string = $cgi->param('schema'); +    %> <INPUT TYPE="hidden" NAME="schema" VALUE="<%=$schema_string%>"> <% +    %schema = map { /^\s*(\w+)\s*=>\s*(\w+)\s*$/ +                      or die "guru meditation #420: $_"; +                    ( $1 => $2 ); +                  } +              split( /\n/, $schema_string ); +  } + +  #first page +  unless ( $cgi->param('magic') ) { %> + +    <INPUT TYPE="hidden" NAME="magic" VALUE="process"> +    <%= hashmaker('schema', [ $schema->tables ], +                            [ grep !/^h_/, dbdef->tables ],  ) %> +    <br><INPUT TYPE="submit" VALUE="done"> +    <% + +  #second page +  } elsif ( $cgi->param('magic') eq 'process' ) { %> + +    <INPUT TYPE="hidden" NAME="magic" VALUE="process2"> +    <% + +    my %unique; +    foreach my $table ( keys %schema ) { + +      my @from_columns = $schema->table($table)->columns; +      my @fs_columns = dbdef->table($schema{$table})->columns; + +      %> +      <%= hashmaker( $table.'__'.$unique{$table}++, +                     \@from_columns => \@fs_columns, +                     $table         =>  $schema{$table}, ) %> +      <br><hr><br> +      <% + +    } + +    %> +    <br><INPUT TYPE="submit" VALUE="done"> +    <% + +  #third (results) +  } elsif ( $cgi->param('magic') eq 'process2' ) { + +    print "<pre>\n"; + +    my %unique; +    foreach my $table ( keys %schema ) { +      ( my $spaces = $table ) =~ s/./ /g; +      print "'$table' => { 'table' => '$schema{$table}',\n". +            #(length($table) x ' '). "         'map'   => {\n"; +            "$spaces        'map'   => {\n"; +      my %map = map { /^\s*(\w+)\s*=>\s*(\w+)\s*$/ +                         or die "guru meditation #420: $_"; +                       ( $1 => $2 ); +                     } +                 split( /\n/, $cgi->param($table.'__'.$unique{$table}++) ); +      foreach ( keys %map ) { +        print "$spaces                     '$_' => '$map{$_}',\n"; +      } +      print "$spaces                   },\n"; +      print "$spaces      },\n"; + +    } +    print "\n</pre>"; + +  } else { +    warn "unrecognized magic: ". $cgi->param('magic'); +  } + +  %> +</FORM> +</BODY> +</HTML> + +  <% +  #hashmaker widget +  sub hashmaker { +    my($name, $from, $to, $labelfrom, $labelto) = @_; +    my $fromsize = scalar(@$from); +    my $tosize = scalar(@$to); +    "<TABLE><TR><TH>$labelfrom</TH><TH>$labelto</TH></TR><TR><TD>". +        qq!<SELECT NAME="${name}_from" SIZE=$fromsize>\n!. +        join("\n", map { qq!<OPTION VALUE="$_">$_</OPTION>! } sort { $a cmp $b } @$from ). +        "</SELECT>\n<BR>". +      qq!<INPUT TYPE="button" VALUE="refill" onClick="repack_${name}_from()">!. +      '</TD><TD>'. +        qq!<SELECT NAME="${name}_to" SIZE=$tosize>\n!. +        join("\n", map { qq!<OPTION VALUE="$_">$_</OPTION>! } sort { $a cmp $b } @$to ). +        "</SELECT>\n<BR>". +      qq!<INPUT TYPE="button" VALUE="refill" onClick="repack_${name}_to()">!. +      '</TD></TR>'. +      '<TR><TD COLSPAN=2>'. +        qq!<INPUT TYPE="button" VALUE="map" onClick="toke_$name(this.form)">!. +      '</TD></TR><TR><TD COLSPAN=2>'. +      qq!<TEXTAREA NAME="$name" COLS=80 ROWS=8></TEXTAREA>!. +      '</TD></TR></TABLE>'. +      "<script> +            function toke_$name() { +              fromObject = document.OneTrueForm.${name}_from; +              for (var i=fromObject.options.length-1;i>-1;i--) { +                if (fromObject.options[i].selected) +                  fromname = deleteOption_$name(fromObject,i); +              } +              toObject = document.OneTrueForm.${name}_to; +              for (var i=toObject.options.length-1;i>-1;i--) { +                if (toObject.options[i].selected) +                  toname = deleteOption_$name(toObject,i); +              } +              document.OneTrueForm.$name.value = document.OneTrueForm.$name.value + fromname + ' => ' + toname + '\\n'; +            } +            function deleteOption_$name(object,index) { +              value = object.options[index].value; +              object.options[index] = null; +              return value; +            } +            function repack_${name}_from() { +              var object = document.OneTrueForm.${name}_from; +              object.options.length = 0; +              ". join("\n",  +                   map { "addOption_$name(object, '$_');\n" } +                       ( sort { $a cmp $b } @$from )           ). " +            } +            function repack_${name}_to() { +              var object = document.OneTrueForm.${name}_to; +              object.options.length = 0; +              ". join("\n",  +                   map { "addOption_$name(object, '$_');\n" } +                       ( sort { $a cmp $b } @$to )           ). " +            } +            function addOption_$name(object,value) { +              var length = object.length; +              object.options[length] = new Option(value, value, false, false); +            } +      </script>". +      ''; +  } + +%> diff --git a/httemplate/misc/queue.cgi b/httemplate/misc/queue.cgi new file mode 100644 index 000000000..ce9c8fbd3 --- /dev/null +++ b/httemplate/misc/queue.cgi @@ -0,0 +1,47 @@ +<% + +$cgi->param('action') =~ /^(new|del|(retry|remove) selected)$/ +  or die "Illegal action"; +my $action = $1; + +my $job; +if ( $action eq 'new' || $action eq 'del' ) { +  $cgi->param('jobnum') =~ /^(\d+)$/ or die "Illegal jobnum"; +  my $jobnum = $1; +  $job = qsearchs('queue', { 'jobnum' => $1 }) +    or die "unknown jobnum $jobnum - ". +           "it probably completed normally or was removed by another user"; +} + +if ( $action eq 'new' ) { +  my %hash = $job->hash; +  $hash{'status'} = 'new'; +  $hash{'statustext'} = ''; +  my $new = new FS::queue \%hash; +  my $error = $new->replace($job); +  die $error if $error; +} elsif ( $action eq 'del' ) { +  my $error = $job->delete; +  die $error if $error; +} elsif ( $action =~ /^(retry|remove) selected$/ ) { +  foreach my $jobnum ( +    map { /^jobnum(\d+)$/; $1; } grep /^jobnum\d+$/, $cgi->param +  ) { +    my $job = qsearchs('queue', { 'jobnum' => $jobnum }); +    if ( $action eq 'retry selected' && $job ) { #new +      my %hash = $job->hash; +      $hash{'status'} = 'new'; +      $hash{'statustext'} = ''; +      my $new = new FS::queue \%hash; +      my $error = $new->replace($job); +      die $error if $error; +    } elsif ( $action eq 'remove selected' && $job ) { #del +      my $error = $job->delete; +      die $error if $error; +    } +  } +} + +print $cgi->redirect(popurl(2). "browse/queue.cgi"); + +%> diff --git a/httemplate/misc/susp_pkg.cgi b/httemplate/misc/susp_pkg.cgi new file mode 100755 index 000000000..4a19fa830 --- /dev/null +++ b/httemplate/misc/susp_pkg.cgi @@ -0,0 +1,15 @@ +<% + +#untaint pkgnum +my ($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal pkgnum"; +my $pkgnum = $1; + +my $cust_pkg = qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); + +my $error = $cust_pkg->suspend; +&eidiot($error) if $error; + +print $cgi->redirect(popurl(2). "view/cust_main.cgi?".$cust_pkg->getfield('custnum')); + +%> diff --git a/httemplate/misc/unapply-cust_pay.cgi b/httemplate/misc/unapply-cust_pay.cgi new file mode 100755 index 000000000..28643ef6e --- /dev/null +++ b/httemplate/misc/unapply-cust_pay.cgi @@ -0,0 +1,18 @@ +<% + +#untaint paynum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal paynum"; +my $paynum = $1; + +my $cust_pay = qsearchs('cust_pay', { 'paynum' => $paynum } ); +my $custnum = $cust_pay->custnum; + +foreach my $cust_bill_pay ( $cust_pay->cust_bill_pay ) { +  my $error = $cust_bill_pay->delete; +  eidiot($error) if $error; +} + +print $cgi->redirect($p. "view/cust_main.cgi?". $custnum); + +%> diff --git a/httemplate/misc/unprovision.cgi b/httemplate/misc/unprovision.cgi new file mode 100755 index 000000000..8f2a7d13d --- /dev/null +++ b/httemplate/misc/unprovision.cgi @@ -0,0 +1,33 @@ +<% + +my $dbh = dbh; +  +#untaint svcnum +my($query) = $cgi->keywords; +$query =~ /^(\d+)$/; +my $svcnum = $1; + +#my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$svcnum}); +#die "Unknown svcnum!" unless $svc_acct; + +my $cust_svc = qsearchs('cust_svc',{'svcnum'=>$svcnum}); +die "Unknown svcnum!" unless $cust_svc; +#&eidiot(qq!This account has already been audited.  Cancel the  +#    <A HREF="!. popurl(2). qq!view/cust_pkg.cgi?! . $cust_svc->getfield('pkgnum') . +#    qq!pkgnum"> package</A> instead.!)  +#  if $cust_svc->pkgnum ne '' && $cust_svc->pkgnum ne '0'; + +my $custnum = $cust_svc->cust_pkg->custnum; + +my $error = $cust_svc->cancel; + +if ( $error ) { +  %> +<!-- mason kludge --> +<% +  &eidiot($error); +} else { +  print $cgi->redirect(popurl(2)."view/cust_main.cgi?$custnum"); +} + +%> diff --git a/httemplate/misc/unsusp_pkg.cgi b/httemplate/misc/unsusp_pkg.cgi new file mode 100755 index 000000000..500872983 --- /dev/null +++ b/httemplate/misc/unsusp_pkg.cgi @@ -0,0 +1,15 @@ +<% + +#untaint pkgnum +my ($query) = $cgi->keywords; +$query =~ /^(\d+)$/ || die "Illegal pkgnum"; +my $pkgnum = $1; + +my $cust_pkg = qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); + +my $error = $cust_pkg->unsuspend; +&eidiot($error) if $error; + +print $cgi->redirect(popurl(2). "view/cust_main.cgi?".$cust_pkg->getfield('custnum')); + +%> diff --git a/httemplate/misc/upload-batch.cgi b/httemplate/misc/upload-batch.cgi new file mode 100644 index 000000000..cc5346606 --- /dev/null +++ b/httemplate/misc/upload-batch.cgi @@ -0,0 +1,29 @@ +<% + +  my $fh = $cgi->upload('batch_results'); +  my $filename = $cgi->param('batch_results'); +  $filename =~ /^.*[\/\\]([^\/\\]+)$/ or die; +  my $paybatch = $1; + +  my $error = defined($fh) +    ? FS::cust_pay_batch::import_results( { +        'filehandle' => $fh, +        'format'     => $cgi->param('format'), +        'paybatch'   => $paybatch, +      } ) +    : 'No file'; + +  if ( $error ) { +    %> +    <!-- mason kludge --> +    <% +    eidiot($error); +#    $cgi->param('error', $error); +#    print $cgi->redirect( "${p}cust_main-import.cgi +  } else { +    %> +    <!-- mason kludge --> +    <%= header('Batch results upload sucessful') %> <% +  } +%> + | 
