1 package OpenILS::Application::Storage;
2 use OpenSRF::Application;
3 use base qw/OpenSRF::Application/;
5 use OpenSRF::EX qw/:try/;
6 use OpenSRF::Utils::Logger qw/:level/;
8 # Pull this in so we can adjust it's @ISA
9 use OpenILS::Application::Storage::CDBI (1);
11 use OpenILS::Application::Storage::FTS;
13 # Suck in the method publishing modules
14 use OpenILS::Application::Storage::Publisher;
16 # the easy way to get to the logger...
17 my $log = "OpenSRF::Utils::Logger";
23 my $conf = OpenSRF::Utils::SettingsClient->new;
25 $log->debug('Initializing ' . __PACKAGE__ . '...', DEBUG);
27 my $driver = "OpenILS::Application::Storage::Driver::".
28 $conf->config_value( apps => 'open-ils.storage' => app_settings => databases => 'driver');
31 $log->debug("Attempting to load $driver ...", DEBUG);
34 throw OpenILS::EX::PANIC ( "Can't load $driver! : $@" ) if ($@);
36 $log->debug("$driver loaded successfully", DEBUG);
38 @OpenILS::Application::Storage::CDBI::ISA = ( $driver );
43 $log->debug('Running child_init for ' . __PACKAGE__ . '...', DEBUG);
45 my $conf = OpenSRF::Utils::SettingsClient->new;
47 # XXX -- this died... router down?
48 #$log->debug('Prepopulating method_lookup cache', DEBUG);
49 #OpenSRF::Application->method_lookup('crappola');
51 $log->debug('Calling the Driver child_init', DEBUG);
52 OpenILS::Application::Storage::CDBI->child_init(
53 $conf->config_value( apps => 'open-ils.storage' => app_settings => databases => 'database')
56 if (OpenILS::Application::Storage::CDBI->db_Main()) {
57 $log->debug("Success initializing driver!", DEBUG);
67 $log->debug(" XACT --> 'BEGIN'ing transaction for session ".$client->session->session_id,DEBUG);
68 return OpenILS::Application::Storage::CDBI->db_Main->begin_work;
70 __PACKAGE__->register_method(
71 method => 'begin_xaction',
72 api_name => 'open-ils.storage.transaction.begin',
81 $log->debug(" XACT --> 'COMMIT'ing transaction for session ".$client->session->session_id,DEBUG);
82 return OpenILS::Application::Storage::CDBI->db_Main->commit;
84 __PACKAGE__->register_method(
85 method => 'commit_xaction',
86 api_name => 'open-ils.storage.transaction.commit',
92 sub rollback_xaction {
96 $log->debug(" XACT --> 'ROLLBACK'ing transaction for session ".$client->session->session_id,DEBUG);
97 return OpenILS::Application::Storage::CDBI->db_Main->rollback;
99 __PACKAGE__->register_method(
100 method => 'rollback_xaction',
101 api_name => 'open-ils.storage.transaction.rollback',
110 return { map { ( $_ => $obj->$_ ) } ($obj->columns('All')) };
116 return [ map { $self->_cdbi2Hash($_) } @objs ];