X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=bin%2Fpart_pkg-bulk_change;h=5347da6beffd7daea17f2f3c3eb41b7a426c6692;hp=64670debc91a5cb5fb66e79f343a8c11ff3ddf43;hb=8b2094d8837af641d3d28b7a76fa460c7d85456e;hpb=460712dad66eac89cfdc9d09c8a9b31e32e20452 diff --git a/bin/part_pkg-bulk_change b/bin/part_pkg-bulk_change index 64670debc..5347da6be 100755 --- a/bin/part_pkg-bulk_change +++ b/bin/part_pkg-bulk_change @@ -1,43 +1,109 @@ #!/usr/bin/perl use strict; -use vars qw( $opt_r $opt_o $opt_v ); +use vars qw( $opt_r $opt_m $opt_C $opt_p $opt_o $opt_v $opt_t $opt_s $opt_S $opt_z $opt_Z $opt_e $opt_u ); 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('rm:C:p:o:v:t:sSzZe:u:'); my $user = shift or &usage; adminsuidsetup $user; -foreach my $part_pkg ( qsearch('part_pkg', {}) ) { +my %search = (); +$search{'plan'} = $opt_p if $opt_p; +$search{'comment'} = $opt_m if $opt_m; + +my $extra_sql = ''; +$extra_sql = ( keys(%search) ? 'AND' : 'WHERE' ). + " classnum NOT IN ($opt_C)" + if $opt_C; + +foreach my $part_pkg ( qsearch({ 'table' => 'part_pkg', + 'hashref' => \%search, + 'extra_sql' => $extra_sql, + }) + ) +{ 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_e ) { + my %hash = ( + 'pkgpart' => $part_pkg->pkgpart, + 'optionname' => 'setup_fee', + ); + + my $part_pkg_option = qsearchs('part_pkg_option', \%hash); + + if ( $part_pkg_option ) { + $part_pkg_option->optionvalue( + sprintf('%.2f', $part_pkg_option->optionvalue * $opt_e) + ); + my $error = $part_pkg_option->replace; + die $error if $error; + } + } + + if ( $opt_u ) { + my %hash = ( + 'pkgpart' => $part_pkg->pkgpart, + 'optionname' => 'recur_fee', + ); + + my $part_pkg_option = qsearchs('part_pkg_option', \%hash); + + if ( $part_pkg_option ) { + $part_pkg_option->optionvalue( + sprintf('%.2f', $part_pkg_option->optionvalue * $opt_u) + ); + my $error = $part_pkg_option->replace; + die $error if $error; + } + } + + if ( $opt_t || $opt_s || $opt_S || $opt_z || $opt_Z ) { + + $part_pkg->taxclass($opt_t) if $opt_t; + $part_pkg->setup_show_zero('') if $opt_s; + $part_pkg->setup_show_zero('Y') if $opt_S; + $part_pkg->recur_show_zero('') if $opt_z; + $part_pkg->recur_show_zero('Y') if $opt_Z; + + 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 ] [ -p plan ] [ -m comment ] [ -C classnum,classnum ] [ -o option_name -v option_value ] [ -t new_taxclass ] [ -s | -S ] [ -z | -Z ] [ -e multiplier ] [ -u multiplier ] employee_username\n"; } =head1 NAME @@ -46,18 +112,42 @@ cust_main-bulk_change =head1 SYNOPSIS - part_pkg-bulk_change [ -r ] -o option_name -v option_value employee_username + part_pkg-bulk_change [ -r ] [ -p plan ] [ -m comment ] [ -C classnum,classnum ] [ -o option_name -v option_value ] [ -t new_taxclass ] [ -s | -S ] [ -z | -Z ] [ -e multiplier ] [ -u multiplier ] employee_username =head1 DESCRIPTION Command-line tool to change a set of package definitions. +Search options: + -r: recurring package definitions only +-p: packages with this price plan only + +-m: packages with this comment only + +-C: excluding package classnum or classnums (comma-separated list) + +Change options: + -o: part_pkg_option optionname -v: part_pkg_option optionvalue +-t: new taxclass + +-s: Turn off "Show zero setup" + +-S: Turn on "Show zero setup" + +-z: Turn off "Show zero recurring" + +-Z: Turn on "Show zero recurring" + +-e: Multiply setup fee by this value (i.e. 1.05 for a 5% price increase) + +-u: Multiply recurring fee by this value (i.e. 1.05 for a 5% price increase) + employee_username =head1 BUGS