package LedgerSMB::Batch; use base qw(LedgerSMB::DBObject); sub create { $self = shift @_; my ($ref) = $self->exec_method(funcname => 'batch_create'); $self->{id} = $ref->{batch_create}; $self->{dbh}->commit; return $ref->{id}; } sub delete_voucher { my ($self, $voucher_id) = @_; $self->call_procedure(procname => 'voucher__delete', args => [$voucher_id]); $self->{dbh}->commit; } sub get_search_criteria { $self = shift @_; @{$self->{batch_classes}} = $self->exec_method( funcname => 'batch_list_classes' ); @{$self->{batch_users}} = $self->exec_method( funcname => 'batch_get_users' ); unshift @{$self->{batch_users}}, {username => $self->{_locale}->text('Any'), id => '0', entity_id => ''}; } sub get_search_results { my ($self) = @_; @{$self->{search_results}} = $self->exec_method(funcname => 'batch_search'); return @{$self->{search_results}}; } sub post { my ($self) = @_; ($self->{post_return_ref}) = $self->exec_method(funcname => 'batch_post'); $self->{dbh}->commit; return $self->{post_return_ref}; } sub delete { my ($self) = @_; ($self->{delete_ref}) = $self->exec_method(funcname => 'batch_delete'); $self->{dbh}->commit; return $self->{delete_ref}; } sub list_vouchers { my ($self) = @_; @{$self->{vouchers}} = $self->exec_method(funcname => 'voucher_list'); return @{$self->{vouchers}}; } 1;