diff options
author | ivan <ivan> | 2009-06-03 19:53:00 +0000 |
---|---|---|
committer | ivan <ivan> | 2009-06-03 19:53:00 +0000 |
commit | abf954d77aadafc9b1975be8aa0135815cfc094e (patch) | |
tree | 001fce5055a52e047d79c8db17e5a904bb3fbe85 | |
parent | 7aa7957f600775b8159e7fa7eff69117066d8336 (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.pm | 35 |
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); } |