[freeside-commits] freeside/httemplate/misc/process recharge_svc.new, NONE, 1.1 tax-import.cgi, NONE, 1.1

Jeff Finucane,420,, jeff at wavetail.420.am
Mon Mar 31 17:54:46 PDT 2008


Update of /home/cvs/cvsroot/freeside/httemplate/misc/process
In directory wavetail.420.am:/tmp/cvs-serv19578/httemplate/misc/process

Added Files:
	recharge_svc.new tax-import.cgi 
Log Message:
checkpoint of new tax rating system

--- NEW FILE: recharge_svc.new ---
%
%
%#untaint svcnum
%my $svcnum = $cgi->param('svcnum');
%$svcnum =~ /^(\d+)$/ || die "Illegal svcnum";
%$svcnum = $1;
%
%#untaint prepaid
%my $prepaid = $cgi->param('prepaid');
%$prepaid =~ /^(\w*)$/;
%$prepaid = $1;

%#untaint payby
%my $payby = $cgi->param('payby');
%$payby =~ /^([A-Z]*)$/;
%$payby = $1;
%
%my $error = '';
%my $svc_acct = qsearchs( 'svc_acct', {'svcnum'=>$svcnum} );
%$error = "Can't recharge service $svcnum. " unless $svc_acct;
%
%my $cust_main = $svc_acct->cust_svc->cust_pkg->cust_main;
%
%my $oldAutoCommit = $FS::UID::AutoCommit;
%local $FS::UID::AutoCommit = 0;
%my $dbh = dbh;
%
%
%unless ($error) {
%
%  my ($amount, $seconds, $up, $down, $total) = (0, 0, 0, 0, 0);
%  #should probably use payby.pm but whatever
%  if ($payby eq 'PREP') {
%    $error = $cust_main->get_prepay($prepaid, \$amount, \$seconds, \$up, \$down, \$total)
%          || $svc_acct->increment_seconds($seconds)
%          || $svc_acct->increment_upbytes($up)
%          || $svc_acct->increment_downbytes($down)
%          || $svc_acct->increment_totalbytes($total)
%          || $cust_main->insert_cust_pay_prepay( $amount, $prepaid );
%  } elsif ( $payby =~ /^(CARD|DCRD|CHEK|DCHK|LECB|BILL|COMP)$/ ) {
%    my $part_pkg = $svc_acct->cust_svc->cust_pkg->part_pkg;
%    $amount = $part_pkg->option('recharge_amount', 1);
%    my %rhash = map { $_ =~ /^recharge_(.*)$/; $1, $part_pkg->option($_, 1) }
%      qw ( recharge_seconds recharge_upbytes recharge_downbytes
%           recharge_totalbytes );
%
%    my $description = "Recharge";
%    $description .= " $rhash{seconds}s" if $rhash{seconds};
%    $description .= " $rhash{upbytes} up" if $rhash{upbytes};
%    $description .= " $rhash{downbytes} down" if $rhash{downbytes};
%    $description .= " $rhash{totalbytes} total" if $rhash{totalbytes};
%
%    $error = $cust_main->charge($amount, "Recharge " . $svc_acct->label,
%                                $description, $part_pkg->taxclass);
%
%    $error ||= $svc_acct->recharge(\%rhash);
%
%    my $old_balance = $cust_main->balance;
%    $error ||= $cust_main->bill;
%    $error ||= $cust_main->apply_payments_and_credits;
%    my $bill_error = $cust_main->collect('realtime' => 1) unless $error;
%    $error ||= "Failed to collect - $bill_error"
%      if $cust_main->balance > $old_balance && $cust_main->balance > 0
%          && $payby ne 'BILL';
%
%  } else {
%    $error = "fatal error - unknown payby: $payby";
%  }
%}
%
%if ($error) {
%  $cgi->param('error', $error);
%  $dbh->rollback if $oldAutoCommit;
%  print $cgi->redirect(popurl(2). "recharge_svc.html?". $cgi->query_string );
%}
%$dbh->commit or die $dbh->errstr if $oldAutoCommit;
%
<% header("Package recharged") %>
  <SCRIPT TYPE="text/javascript">
    window.top.location.reload();
  </SCRIPT>
  </BODY></HTML>
<%init>
my $conf = new FS::Conf;
</%init>

--- NEW FILE: tax-import.cgi ---
% if ( $error ) {
%   warn $error;
%   errorpage($error);
%  } else {
    <% include('/elements/header.html','Import successful') %> 
    <% include('/elements/footer.html') %> 
%  }
<%init>

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right('Import');

my $cfh = $cgi->upload('codefile');
my $zfh = $cgi->upload('plus4file');
my $tfh = $cgi->upload('txmatrix');
my $dfh = $cgi->upload('detail');
#warn $cgi;
#warn $fh;

my $oldAutoCommit = $FS::UID::AutoCommit;
local $FS::UID::AutoCommit = 0;
my $dbh = dbh;

my $error = defined($cfh)
  ? FS::tax_class::batch_import( {
      filehandle => $cfh,
      'format'   => scalar($cgi->param('format')),
    } )
  : 'No code file';

$error ||= defined($zfh)
  ? FS::cust_tax_location::batch_import( {
      filehandle => $zfh,
      'format'   => scalar($cgi->param('format')),
    } )
  : 'No plus4 file';

$error ||= defined($tfh)
  ? FS::part_pkg_taxrate::batch_import( {
      filehandle => $tfh,
      'format'   => scalar($cgi->param('format')),
    } )
  : 'No tax matrix file';

$error ||= defined($dfh)
  ? FS::tax_rate::batch_import( {
      filehandle => $dfh,
      'format'   => scalar($cgi->param('format')),
    } )
  : 'No tax detail file';

if ($error) {
  $dbh->rollback or die $dbh->errstr if $oldAutoCommit;
}else{
  $dbh->commit or die $dbh->errstr if $oldAutoCommit;
}

</%init>



More information about the freeside-commits mailing list