X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Frate.pm;h=f19ebf00231a740a8059f6bcea48afa2a162b823;hb=d33015393db77e9bc8e0deeb1a39500b3b5a49eb;hp=7f625a6b1cc6765073000368201f8e24ac68d279;hpb=6cf964d0dc008621fb30fd2da28e2c44f29c6364;p=freeside.git diff --git a/FS/FS/rate.pm b/FS/FS/rate.pm index 7f625a6b1..f19ebf002 100644 --- a/FS/FS/rate.pm +++ b/FS/FS/rate.pm @@ -307,25 +307,26 @@ Experimental job-queue processor for web interface adds/edits =cut +use Storable qw(thaw); +use Data::Dumper; +use MIME::Base64; sub process { my $job = shift; - #my %param = @_; + my $param = thaw(decode_base64(shift)); + warn Dumper($param) if $DEBUG; - my $param = shift; - my %param = split(/[;=]/, $param); - - my $old = qsearchs('rate', { 'ratenum' => $param{'ratenum'} } ) - if $param{'ratenum'}; + my $old = qsearchs('rate', { 'ratenum' => $param->{'ratenum'} } ) + if $param->{'ratenum'}; my @rate_detail = map { my $regionnum = $_->regionnum; - if ( $param{"sec_granularity$regionnum"} ) { + if ( $param->{"sec_granularity$regionnum"} ) { new FS::rate_detail { 'dest_regionnum' => $regionnum, - map { $_ => $param{"$_$regionnum"} } + map { $_ => $param->{"$_$regionnum"} } qw( min_included min_charge sec_granularity ) }; @@ -343,13 +344,13 @@ sub process { } qsearch('rate_region', {} ); my $rate = new FS::rate { - map { $_ => $param{$_} } + map { $_ => $param->{$_} } fields('rate') }; my $error = ''; - if ( $param{'ratenum'} ) { - warn "$rate replacing $old ($param{'ratenum'})\n" if $DEBUG; + if ( $param->{'ratenum'} ) { + warn "$rate replacing $old (". $param->{'ratenum'}. ")\n" if $DEBUG; $error = $rate->replace( $old, 'rate_detail' => \@rate_detail, 'job' => $job, @@ -366,51 +367,6 @@ sub process { } -# begin JSRPC code... - -package FS::rate::JSRPC; -use vars qw(@ISA $DEBUG); -use JavaScript::RPC::Server::CGI; -use FS::UID; -@ISA = qw( JavaScript::RPC::Server::CGI ); -$DEBUG = 1; - -sub process_rate { - my $self = shift; - - my %param = @_; - warn "FS::rate::JSRPC::process_rate\n". - join('', map " $_ => $param{$_}\n", keys %param ) - if $DEBUG; - - #progressbar prototype code... should be generalized - - #first get the CGI params shipped off to a job ASAP so an id can be returned - #to the caller - - my $job = new FS::queue { 'job' => 'FS::rate::process' }; - - #too slow to insert all the cgi params as individual args..,? - #my $error = $queue->insert('_JOB', $cgi->Vars); - - #my $bigstring = join(';', map { "$_=". scalar($cgi->param($_)) } $cgi->param ); - my $bigstring = join(';', map { "$_=". $param{$_} } keys %param ); - my $error = $job->insert('_JOB', $bigstring); - - if ( $error ) { - $error; - } else { - $job->jobnum; - } - -} - -sub get_new_query { - FS::UID::cgi(); -} - -# end JSRPC code... - =head1 BUGS =head1 SEE ALSO