$dbh->begin_work;
# setup dbup_ export vars & run script
+ my $old_dbh = $::form->set_standard_dbh($dbh);
my %dbup_myconfig = map { ($_ => $::form->{$_}) } qw(dbname dbuser dbpasswd dbhost dbport dbconnect);
my $result = eval {
SL::DBUpgrade2::Base::execute_script(
my $error = $EVAL_ERROR;
+ $::form->set_standard_dbh($old_dbh);
+
$dbh->rollback if 1 != ($result // -1);
return $error if $self->{return_on_error} && (1 != ($result // -1));
use parent qw(Rose::Object);
use Rose::Object::MakeMethods::Generic (
- 'scalar --get_set_init' => [ qw(data currencies) ],
+ 'scalar --get_set_init' => [ qw(data currencies default_currency _table_currencies_exists) ],
);
sub init_data {
return {} if !$::auth->client;
+ return SL::DBUtils::selectfirst_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT * FROM defaults|);
+}
- my $dbh = $::form->get_standard_dbh;
- my $data = SL::DBUtils::selectfirst_hashref_query($::form, $dbh, qq|SELECT * FROM defaults|);
- $data->{default_currency} = (SL::DBUtils::selectfirst_array_query($::form, $dbh, qq|SELECT name FROM currencies WHERE id = ?|, $data->{currency_id}))[0] if $data->{currency_id};
-
- return $data;
+sub init__table_currencies_exists {
+ return 0 if !$::auth->client;
+ return !!(SL::DBUtils::selectall_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT tablename FROM pg_tables WHERE (schemaname = 'public') AND (tablename = 'currencies')|))[0];
}
sub init_currencies {
- return [] if !$::auth->client;
+ my ($self) = @_;
+
+ return [] if !$self->_table_currencies_exists;
return [ map { $_->{name} } SL::DBUtils::selectall_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT name FROM currencies ORDER BY id ASC|) ];
}
+sub init_default_currency {
+ my ($self) = @_;
+
+ return undef if !$self->_table_currencies_exists || !$self->data->{currency_id};
+ return (SL::DBUtils::selectfirst_array_query($::form, $::form->get_standard_dbh, qq|SELECT name FROM currencies WHERE id = ?|, $self->data->{currency_id}))[0];
+}
+
sub reload {
- my ($self) = @_;
- $self->{data} = $self->init_data;
- $self->{currencies} = $self->init_currencies;
+ my ($self) = @_;
+
+ delete @{ $self }{qw(data currencies default_currency)};
+
return $self;
}