summaryrefslogtreecommitdiff
path: root/bin
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2013-08-17 22:38:57 -0700
committerIvan Kohler <ivan@freeside.biz>2013-08-17 22:38:57 -0700
commit86f99dcdb9a51acc6865dc11b481f51377efecf6 (patch)
tree7836371f08e975e44cf6db3ca4b7788ac6b4b950 /bin
parent0972e744b4b542550013a470f8b08cb090094a0f (diff)
add -t flat to part_pkg-bulk_change
Diffstat (limited to 'bin')
-rwxr-xr-xbin/part_pkg-bulk_change59
1 files changed, 39 insertions, 20 deletions
diff --git a/bin/part_pkg-bulk_change b/bin/part_pkg-bulk_change
index 64670debc..21a6c5ac3 100755
--- a/bin/part_pkg-bulk_change
+++ b/bin/part_pkg-bulk_change
@@ -1,14 +1,14 @@
#!/usr/bin/perl
use strict;
-use vars qw( $opt_r $opt_o $opt_v );
+use vars qw( $opt_r $opt_o $opt_v $opt_t );
use Getopt::Std;
use FS::UID qw(adminsuidsetup);
use FS::Record qw(qsearch qsearchs);
use FS::part_pkg;
use FS::part_pkg_option;
-getopts('ro:v:');
+getopts('ro:v:t:');
my $user = shift or &usage;
adminsuidsetup $user;
@@ -16,28 +16,41 @@ adminsuidsetup $user;
foreach my $part_pkg ( qsearch('part_pkg', {}) ) {
next if ! $part_pkg->freq && $opt_r;
- my %hash = (
- 'pkgpart' => $part_pkg->pkgpart,
- 'optionname' => $opt_o,
- );
-
- my $part_pkg_option = qsearchs('part_pkg_option', \%hash);
-
- if ( $part_pkg_option ) {
- next if $part_pkg_option->optionvalue eq $opt_v;
- $part_pkg_option->optionvalue($opt_v);
- my $error = $part_pkg_option->replace;
- die $error if $error;
- } else {
- $part_pkg_option = new FS::part_pkg_option { %hash, 'optionvalue'=>$opt_v };
- my $error = $part_pkg_option->insert;
- die $error if $error;
+ if ( $opt_o ) {
+
+ my %hash = (
+ 'pkgpart' => $part_pkg->pkgpart,
+ 'optionname' => $opt_o,
+ );
+
+ my $part_pkg_option = qsearchs('part_pkg_option', \%hash);
+
+ if ( $part_pkg_option ) {
+ next if $part_pkg_option->optionvalue eq $opt_v;
+ $part_pkg_option->optionvalue($opt_v);
+ my $error = $part_pkg_option->replace;
+ die $error if $error;
+ } else {
+ $part_pkg_option = new FS::part_pkg_option { %hash,
+ 'optionvalue'=>$opt_v,
+ };
+ my $error = $part_pkg_option->insert;
+ die $error if $error;
+ }
+
+ }
+
+ if ( $opt_t ) {
+
+ $part_pkg->taxclass($opt_t);
+ my $error = $part_pkg->replace;
+
}
}
sub usage {
- die "usage: part_pkg-bulk_change [ -r ] -o option_name -v option_value employee_username\n";
+ die "usage: part_pkg-bulk_change [ -r ] [ -o option_name -v option_value ] [ -t new_taxclass ] employee_username\n";
}
=head1 NAME
@@ -46,18 +59,24 @@ cust_main-bulk_change
=head1 SYNOPSIS
- part_pkg-bulk_change [ -r ] -o option_name -v option_value employee_username
+ part_pkg-bulk_change [ -r ] [ -o option_name -v option_value ] [ -t new_taxclass ] employee_username
=head1 DESCRIPTION
Command-line tool to change a set of package definitions.
+Search options:
+
-r: recurring package definitions only
+Change options:
+
-o: part_pkg_option optionname
-v: part_pkg_option optionvalue
+-t: new taxclass
+
employee_username
=head1 BUGS