#!/usr/bin/perl

use strict;
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('rm:C:p:o:v:t:sSzZe:u:');

my $user = shift or &usage;
adminsuidsetup $user;

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;

  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 ] [ -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

cust_main-bulk_change

=head1 SYNOPSIS

  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

=head1 SEE ALSO

L<FS::part_pkg>

=cut

1;

