summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorivan <ivan>2009-06-03 19:53:00 +0000
committerivan <ivan>2009-06-03 19:53:00 +0000
commitabf954d77aadafc9b1975be8aa0135815cfc094e (patch)
tree001fce5055a52e047d79c8db17e5a904bb3fbe85
parent7aa7957f600775b8159e7fa7eff69117066d8336 (diff)
add a hack to set default schema, cf. http://www.freeside.biz/mediawiki/index.php/Freeside:1.7:Documentation:Administration:PostgreSQL_Schema
-rw-r--r--FS/FS/UID.pm35
1 files changed, 25 insertions, 10 deletions
diff --git a/FS/FS/UID.pm b/FS/FS/UID.pm
index 0f11c2b53..11c467958 100644
--- a/FS/FS/UID.pm
+++ b/FS/FS/UID.pm
@@ -2,9 +2,9 @@ package FS::UID;
use strict;
use vars qw(
- @ISA @EXPORT_OK $cgi $dbh $freeside_uid $user
- $conf_dir $cache_dir $secrets $datasrc $db_user $db_pass %callback @callback
- $driver_name $AutoCommit
+ @ISA @EXPORT_OK $cgi $freeside_uid $user $conf_dir $cache_dir
+ $secrets $datasrc $db_user $db_pass $schema $dbh $driver_name
+ $AutoCommit %callback @callback
);
use subs qw(
getsecrets cgisetotaker
@@ -116,12 +116,24 @@ sub forksuidsetup {
}
sub myconnect {
- DBI->connect( getsecrets(@_), { 'AutoCommit' => 0,
- 'ChopBlanks' => 1,
- 'ShowErrorStatement' => 1,
- }
- )
+ my $handle = DBI->connect( getsecrets(@_), { 'AutoCommit' => 0,
+ 'ChopBlanks' => 1,
+ 'ShowErrorStatement' => 1,
+ }
+ )
or die "DBI->connect error: $DBI::errstr\n";
+
+ if ( $schema ) {
+ use DBIx::DBSchema::_util qw(_load_driver ); #quelle hack
+ my $driver = _load_driver($handle);
+ if ( $driver =~ /^Pg/ ) {
+ no warnings 'redefine';
+ eval "sub DBIx::DBSchema::DBD::${driver}::default_db_schema {'$schema'}";
+ die $@ if $@;
+ }
+ }
+
+ $handle;
}
=item install_callback
@@ -290,10 +302,13 @@ sub getsecrets {
$secrets = 'secrets';
}
- ($datasrc, $db_user, $db_pass) = $conf->config($secrets)
+ ($datasrc, $db_user, $db_pass, $schema) = $conf->config($secrets)
or die "Can't get secrets: $secrets: $!\n";
- $FS::Conf::default_dir = $conf_dir. "/conf.$datasrc";
undef $driver_name;
+
+ no warnings 'once';
+ $FS::Conf::default_dir = $conf_dir. "/conf.$datasrc";
+
($datasrc, $db_user, $db_pass);
}