X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=bin%2Fpart_pkg-bulk_change;h=c882954bf9cff02ff8d976e705d92ec1971f11f9;hb=30026a09a72bb16b8c7e17035250b9d797bd47e2;hp=0c7bc1dd710aa3509a74dcccf65be27f3590ccae;hpb=a541a59a156998b7d0c310fc74f7e528431a6716;p=freeside.git diff --git a/bin/part_pkg-bulk_change b/bin/part_pkg-bulk_change index 0c7bc1dd7..c882954bf 100755 --- a/bin/part_pkg-bulk_change +++ b/bin/part_pkg-bulk_change @@ -1,7 +1,7 @@ #!/usr/bin/perl use strict; -use vars qw( $opt_r $opt_p $opt_o $opt_v $opt_s $opt_S $opt_z $opt_Z ); +use vars qw( $opt_r $opt_m $opt_p $opt_o $opt_v $opt_t $opt_s $opt_S $opt_z $opt_Z ); use Getopt::Std; use FS::UID qw(adminsuidsetup); use FS::Record qw(qsearch qsearchs); @@ -20,22 +20,28 @@ $search{'comment'} = $opt_m if $opt_m; foreach my $part_pkg ( qsearch('part_pkg',\%search) ) { 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 || $opt_s || $opt_S || $opt_z || $opt_Z ) {