1 package Koha
::Plugins
::Handler
;
3 # Copyright 2012 Kyle Hall
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
22 use Array
::Utils
qw(array_minus);
23 use File
::Path
qw(remove_tree);
25 use Module
::Load
qw(load);
28 use Koha
::Plugins
::Methods
;
31 my $pluginsdir = C4
::Context
->config("pluginsdir");
32 my @pluginsdir = ref($pluginsdir) eq 'ARRAY' ? @
$pluginsdir : $pluginsdir;
33 push @INC, array_minus
(@pluginsdir, @INC) ;
34 pop @INC if $INC[-1] eq '.' ;
39 Koha::Plugins::Handler - Handler Module for running plugins
43 Koha::Plugins::Handler->run({ class => $class, method => $method, cgi => $cgi });
57 my ( $class, $args ) = @_;
59 return unless ( C4
::Context
->config("enable_plugins") || $args->{'enable_plugins'} );
61 my $plugin_class = $args->{'class'};
62 my $plugin_method = $args->{'method'};
63 my $cgi = $args->{'cgi'};
64 my $params = $args->{'params'};
66 my $has_method = Koha
::Plugins
::Methods
->search({ plugin_class
=> $plugin_class, plugin_method
=> $plugin_method })->count();
69 my $plugin = $plugin_class->new( { cgi
=> $cgi, enable_plugins
=> $args->{'enable_plugins'} } );
70 return $plugin->$plugin_method( $params );
72 warn "Plugin does not have method $plugin_method";
84 my ( $class, $args ) = @_;
86 return unless ( C4
::Context
->config("enable_plugins") || $args->{'enable_plugins'} );
88 my $plugin_class = $args->{'class'};
90 my $plugin_path = $plugin_class;
91 $plugin_path =~ s/::/\//g; # Take class name, transform :: to / to get path
92 $plugin_path =~ s/$/.pm/; # Add .pm to the end
93 require $plugin_path; # Require the plugin to have it's path listed in INC
95 $INC{$plugin_path}; # Get the full true path to the plugin from INC
96 $plugin_path =~ s/.pm//; # Remove the .pm from the end
98 Koha
::Plugins
::Handler
->run({
99 class => $plugin_class,
100 method
=> 'uninstall',
101 enable_plugins
=> $args->{enable_plugins
},
104 C4
::Context
->dbh->do( "DELETE FROM plugin_data WHERE plugin_class = ?", undef, ($plugin_class) );
105 Koha
::Plugins
::Methods
->search({ plugin_class
=> $plugin_class })->delete();
107 unlink "$plugin_path.pm" or warn "Could not unlink $plugin_path.pm: $!";
108 remove_tree
($plugin_path);
118 Kyle M Hall <kyle.m.hall@gmail.com>