summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xLedgerSMB.pm2
-rw-r--r--LedgerSMB/DBObject.pm24
-rw-r--r--LedgerSMB/Employee.pm84
-rwxr-xr-xLedgerSMB/Form.pm2
4 files changed, 102 insertions, 10 deletions
diff --git a/LedgerSMB.pm b/LedgerSMB.pm
index e6939122..2c82bf7c 100755
--- a/LedgerSMB.pm
+++ b/LedgerSMB.pm
@@ -532,7 +532,7 @@ sub callproc {
$argstr .= "?, ";
}
$argstr =~ s/\, $//;
- $query = "SELECT $procname";
+ $query = "SELECT * FROM $procname";
$query =~ s/\(\)/$argstr/;
my $sth = $self->{dbh}->prepare($query);
while (my $ref = $sth->fetchrow_hashref(NAME_lc)){
diff --git a/LedgerSMB/DBObject.pm b/LedgerSMB/DBObject.pm
index 77869f7f..e2441beb 100644
--- a/LedgerSMB/DBObject.pm
+++ b/LedgerSMB/DBObject.pm
@@ -8,25 +8,28 @@ This module creates object instances based on LedgerSMB's in-database ORM.
=head1 METHODS
-Most methods are dynamically created. The following methods are static, however.
+=item find_method ($hashref, $function_name, @args)
-=item make_object hashref, string,
-This creates a new data object instance based on information in the PostgreSQL
-catalogs.
+=head1 Copyright (C) 2007, The LedgerSMB core team.
+This file is licensed under the Gnu General Public License version 2, or at your
+option any later version. A copy of the license should have been included with
+your software.
=back
=cut
-use LedgerSMB;
package LedgerSMB::DBObject;
+use LedgerSMB;
use strict;
no strict 'refs';
use warnings;
-sub AUTOLOAD {
- my ($ref) = shift @_;
+@ISA = (LedgerSMB);
+
+sub exec_method {
+ my ($self) = shift @_;
my ($funcname) = shift @_;
my $query =
@@ -36,6 +39,11 @@ sub AUTOLOAD {
my $ref;
$ref = $sth->fetchrow_hashref(NAME_lc);
+
+ if (!$ref){ # no such function
+ $self->error($locale->text("No such function: ") .$funcname;
+ die;
+ }
my $m_name = $ref->{proname};
my $args = $ref->{proargnames};
my @proc_args;
@@ -53,5 +61,5 @@ sub AUTOLOAD {
@proc_args = @_;
}
}
- LedgerSMB::callproc($funcname, @proc_args);
+ $self->callproc($funcname, @proc_args);
}
diff --git a/LedgerSMB/Employee.pm b/LedgerSMB/Employee.pm
new file mode 100644
index 00000000..007b44d5
--- /dev/null
+++ b/LedgerSMB/Employee.pm
@@ -0,0 +1,84 @@
+=head1 NAME
+
+LedgerSMB::Employee - LedgerSMB class for managing Employees
+
+=head1 SYOPSIS
+
+This module creates object instances based on LedgerSMB's in-database ORM.
+
+=head1 METHODS
+
+The following method is static:
+=item new ($LedgerSMB object);
+
+=item merge ($hashref, @attrs)
+copies @attrs from $hashref to $self.
+
+The following methods are passed through to stored procedures via Autoload.
+=item save
+=item get
+=item search
+=item list_managers
+
+The above list may grow over time, and may depend on other installed modules.
+
+=head1 Copyright (C) 2007, The LedgerSMB core team.
+This file is licensed under the Gnu General Public License version 2, or at your
+option any later version. A copy of the license should have been included with
+your software.
+
+=back
+
+=cut
+
+package LedgerSMB::Employee;
+use LedgerSMB;
+use LedgerSMB::DBObject;
+@ISA = (LedgerSMB, LedgerSMB::DBObject);
+
+sub AUTOLOAD {
+ my $procname = "employee_$LedgerSMB::Employee::Autoload";
+ $self->exec_method($procname);
+}
+
+sub new {
+ my $lsmb = shift @_;
+ if (! $lsmb->isa(LedgerSMB)){
+ $self->error("Employee called without LedgerSMB object arg");
+ my $self = {};
+ for $attr (keys $lsmb){
+ $self->{$attr} = $lsmb->{$attr};
+ }
+ bless $self;
+}
+
+
+sub merge {
+ my $self = shift @_;
+ my $src = shift @_;
+ for $arg (@_){
+ $self->{$arg} = $src->{$arg};
+ }
+}
+
+sub save {
+ my $hashref = shift ($self->exec_method("employee_save"));
+ $self->merge($hashref, 'id');
+}
+
+sub get {
+ my $hashref = shift ($self->exec_method("employee_get"));
+ $self->merge($hashref, keys $hashref);
+}
+
+sub delete {
+ $self->exec_method("employee_delete");
+}
+
+sub list_managers {
+ $self->{manager_list} = $self->exec_method("employee_list_managers");
+}
+
+sub search {
+ $self->{search_results} = $self->exec_method("employee_search");
+}
diff --git a/LedgerSMB/Form.pm b/LedgerSMB/Form.pm
index d728f428..8f51c2ff 100755
--- a/LedgerSMB/Form.pm
+++ b/LedgerSMB/Form.pm
@@ -532,7 +532,7 @@ sub callproc {
$argstr .= "?, ";
}
$argstr =~ s/\, $//;
- $query = "SELECT $procname";
+ $query = "SELECT * FROM $procname";
$query =~ s/\(\)/$argstr/;
my $sth = $self->{dbh}->prepare($query);
while (my $ref = $sth->fetchrow_hashref(NAME_lc)){