diff options
author | Ivan Kohler <ivan@freeside.biz> | 2016-04-28 11:59:44 -0700 |
---|---|---|
committer | Ivan Kohler <ivan@freeside.biz> | 2016-04-28 11:59:44 -0700 |
commit | d39884aa7ef13f26a39e6db0c305b98aa61943e1 (patch) | |
tree | 4406b2ce06a767b8f36b701bc55f5428dfb89735 | |
parent | 051449daeb488ac38f380392d6e42d9f6408d892 (diff) |
bulk queue update tool, RT#42042
-rw-r--r-- | bin/queue-bulk_change | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/bin/queue-bulk_change b/bin/queue-bulk_change new file mode 100644 index 000000000..4fc22b3aa --- /dev/null +++ b/bin/queue-bulk_change @@ -0,0 +1,34 @@ +#!/usr/bin/perl + +use strict; +#use Getopt::Std; +use FS::UID qw( adminsuidsetup ); +use FS::Record qw( qsearch qsearchs ); +use FS::queue_arg; +use FS::queue; + +my $user = shift or &usage; +adminsuidsetup $user; + +my $from = shift or &usage; +my $to = shift or &usage; + +foreach my $queue_arg ( qsearch('queue_arg', { 'arg' => $from, } ) ) { + + $queue_arg->arg($to); + my $error = $queue_arg->replace; + die $error if $error; + + #not on 3.x my $queue = $queue_arg->queue; + my $queue = qsearchs( 'queue', { 'jobnum' => $queue_arg->jobnum } ); + if ( $queue->status eq 'failed' ) { + $queue->status('new'); + my $error = $queue->replace; + die $error if $error; + } + +} + +sub usage { + die "usage: queue-bulk_chage employee_username from_arg to_arg\n"; +} |