sub new {
my ( $class, $args ) = @_;
- die('Plugins not enabled in config') unless ( C4::Context->config("enable_plugins") || $args->{'enable_plugins'} );
+ return unless ( C4::Context->config("enable_plugins") || $args->{'enable_plugins'} );
$args->{'pluginsdir'} = C4::Context->config("pluginsdir");
sub new {
my ( $class, $args ) = @_;
- die('Plugins not enabled in config') unless ( C4::Context->config("enable_plugins") || $args->{'enable_plugins'} );
+ return unless ( C4::Context->config("enable_plugins") || $args->{'enable_plugins'} );
$args->{'class'} = $class;
$args->{'template'} = Template->new( { ABSOLUTE => 1 } );
sub run {
my ( $class, $args ) = @_;
- die('Plugins not enabled in config') unless ( C4::Context->config("enable_plugins") || $args->{'enable_plugins'} );
+ return unless ( C4::Context->config("enable_plugins") || $args->{'enable_plugins'} );
my $plugin_class = $args->{'class'};
my $plugin_method = $args->{'method'};
if ( can_load( modules => { $plugin_class => undef } ) ) {
my $plugin = $plugin_class->new( { cgi => $cgi } );
if ( $plugin->can($plugin_method) ) {
- $plugin->$plugin_method();
+ return $plugin->$plugin_method();
} else {
warn "Plugin does not have method $plugin_method";
}
--- /dev/null
+[% INCLUDE 'doc-head-open.inc' %]
+<title>Koha › Tools › Plugins › Upload Plugin
+ </title>
+[% INCLUDE 'doc-head-close.inc' %]
+[% INCLUDE 'calendar.inc' %]
+</head>
+
+<body>
+[% INCLUDE 'header.inc' %]
+[% INCLUDE 'circ-search.inc' %]
+
+<div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a>
+› <a href="/cgi-bin/koha/plugins/plugins-home.pl">Plugins</a>
+› Plugins disabled
+</div>
+
+<div id="doc3" class="yui-t2">
+ <div id="bd">
+ <div id="yui-main">
+ <div class="yui-b">
+ <div class="yui-g">
+ <div class="yui-u first">
+ <h1>Plugins disabled!</h1>
+
+ <p>To enable Koha plugins, the system preference UseKohaPlugins must be enabled, and the flag enable_plugins must be set in the Koha configuration file</p>
+ </div>
+ </div>
+ </div>
+</div>
+[% INCLUDE 'intranet-bottom.inc' %]
use C4::Debug;
use C4::Context;
-die("Koha plugins are disabled!")
- unless C4::Context->preference('UseKohaPlugins');
+my $plugins_enabled = C4::Context->preference('UseKohaPlugins') && C4::Context->config("enable_plugins");
my $input = new CGI;
my $method = $input->param('method');
my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
- { template_name => "plugins/plugins-home.tmpl",
- query => $input,
- type => "intranet",
+ { template_name => ($plugins_enabled) ? "plugins/plugins-home.tt" : "plugins/plugins-disabled.tt",
+ query => $input,
+ type => "intranet",
authnotrequired => 0,
flagsrequired => { plugins => '*' },
debug => 1,
}
);
-$template->param(
- koha_version => C4::Context->preference("Version"),
- method => $method,
-);
+if ($plugins_enabled) {
+
+ $template->param(
+ koha_version => C4::Context->preference("Version"),
+ method => $method,
+ );
+
+ my @plugins = Koha::Plugins->new()->GetPlugins($method);
-my @plugins = Koha::Plugins->new()->GetPlugins($method);
+ $template->param( plugins => \@plugins, );
-$template->param( plugins => \@plugins );
+}
output_html_with_http_headers( $input, $cookie, $template->output );
#!/usr/bin/perl
+
#
# This file is part of Koha.
#
use C4::Debug;
use Koha::Plugins;
-die("Koha plugins are disabled!")
- unless C4::Context->preference('UseKohaPlugins');
+my $plugins_enabled = C4::Context->preference('UseKohaPlugins') && C4::Context->config("enable_plugins");
my $input = new CGI;
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
- { template_name => "plugins/plugins-upload.tmpl",
- query => $input,
- type => "intranet",
+ { template_name => ($plugins_enabled) ? "plugins/plugins-upload.tmpl" : "plugins/plugins-disabled.tt",
+ query => $input,
+ type => "intranet",
authnotrequired => 0,
flagsrequired => { plugins => 'manage' },
debug => 1,
my %errors;
-if ( ( $op eq 'Upload' ) && $uploadfile ) {
- my $plugins_dir = C4::Context->config("pluginsdir");
-
- my $dirname = File::Temp::tempdir( CLEANUP => 1 );
- $debug and warn "dirname = $dirname";
+if ($plugins_enabled) {
+ if ( ( $op eq 'Upload' ) && $uploadfile ) {
+ my $plugins_dir = C4::Context->config("pluginsdir");
- my $filesuffix;
- $filesuffix = $1 if $uploadfilename =~ m/(\..+)$/i;
- ( $tfh, $tempfile ) = File::Temp::tempfile( SUFFIX => $filesuffix, UNLINK => 1 );
+ my $dirname = File::Temp::tempdir( CLEANUP => 1 );
+ $debug and warn "dirname = $dirname";
- $debug and warn "tempfile = $tempfile";
+ my $filesuffix;
+ $filesuffix = $1 if $uploadfilename =~ m/(\..+)$/i;
+ ( $tfh, $tempfile ) = File::Temp::tempfile( SUFFIX => $filesuffix, UNLINK => 1 );
- $errors{'NOTKPZ'} = 1 if ( $uploadfilename !~ /\.kpz$/i );
- $errors{'NOWRITETEMP'} = 1 unless ( -w $dirname );
- $errors{'NOWRITEPLUGINS'} = 1 unless ( -w $plugins_dir );
- $errors{'EMPTYUPLOAD'} = 1 unless ( length($uploadfile) > 0 );
+ $debug and warn "tempfile = $tempfile";
- if (%errors) {
- $template->param( ERRORS => [ \%errors ] );
- } else {
- while (<$uploadfile>) {
- print $tfh $_;
- }
- close $tfh;
+ $errors{'NOTKPZ'} = 1 if ( $uploadfilename !~ /\.kpz$/i );
+ $errors{'NOWRITETEMP'} = 1 unless ( -w $dirname );
+ $errors{'NOWRITEPLUGINS'} = 1 unless ( -w $plugins_dir );
+ $errors{'EMPTYUPLOAD'} = 1 unless ( length($uploadfile) > 0 );
- my $ae = Archive::Extract->new( archive => $tempfile, type => 'zip' );
- unless ( $ae->extract( to => $plugins_dir ) ) {
- warn "ERROR: " . $ae->error;
- $errors{'UZIPFAIL'} = $uploadfilename;
+ if (%errors) {
$template->param( ERRORS => [ \%errors ] );
- output_html_with_http_headers $input, $cookie, $template->output;
- exit;
+ } else {
+ while (<$uploadfile>) {
+ print $tfh $_;
+ }
+ close $tfh;
+
+ my $ae = Archive::Extract->new( archive => $tempfile, type => 'zip' );
+ unless ( $ae->extract( to => $plugins_dir ) ) {
+ warn "ERROR: " . $ae->error;
+ $errors{'UZIPFAIL'} = $uploadfilename;
+ $template->param( ERRORS => [ \%errors ] );
+ output_html_with_http_headers $input, $cookie, $template->output;
+ exit;
+ }
}
+ } elsif ( ( $op eq 'Upload' ) && !$uploadfile ) {
+ warn "Problem uploading file or no file uploaded.";
+ }
+
+ if ( $uploadfile && !%errors && !$template->param('ERRORS') ) {
+ print $input->redirect("/cgi-bin/koha/plugins/plugins-home.pl");
+ } else {
+ output_html_with_http_headers $input, $cookie, $template->output;
}
-} elsif ( ( $op eq 'Upload' ) && !$uploadfile ) {
- warn "Problem uploading file or no file uploaded.";
-}
-if ( $uploadfile && !%errors && !$template->param('ERRORS') ) {
- print $input->redirect("/cgi-bin/koha/plugins/plugins-home.pl");
} else {
output_html_with_http_headers $input, $cookie, $template->output;
}
use C4::Debug;
use C4::Context;
-die("Koha plugins are disabled!")
- unless C4::Context->preference('UseKohaPlugins');
+my $plugins_enabled = C4::Context->preference('UseKohaPlugins') && C4::Context->config("enable_plugins");
my $cgi = new CGI;
my $method = $cgi->param('method');
my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
- { template_name => "plugins/plugins-home.tmpl",
+ { template_name => "plugins/plugins-disabled.tmpl",
query => $cgi,
type => "intranet",
authnotrequired => 0,
}
);
-my $plugin = Koha::Plugins::Handler->run( { class => $class, method => $method, cgi => $cgi } );
+if ( $plugins_enabled ) {
+ my $plugin = Koha::Plugins::Handler->run( { class => $class, method => $method, cgi => $cgi } );
+} else {
+ output_html_with_http_headers( $cgi, $cookie, $template->output );
+}
sub report {
my ( $self, $args ) = @_;
- return 1;
+ return "Koha::Plugin::Test::report";
}
sub tool {
my ( $self, $args ) = @_;
- return 1;
+ return "Koha::Plugin::Test::tool";
}
sub configure {
my ( $self, $args ) = @_;
- return 1;
+ return "Koha::Plugin::Test::configure";;
}
sub install {
my ( $self, $args ) = @_;
- return 1;
+ return "Koha::Plugin::Test::install";
}
sub uninstall {
my ( $self, $args ) = @_;
- return 1;
+ return "Koha::Plugin::Test::uninstall";
}
use strict;
use warnings;
-use Test::More tests => 15;
+use Test::More tests => 16;
use File::Basename;
use Module::Load::Conditional qw(can_load);
ok( $plugin->can('install'), 'Test plugin can install' );
ok( $plugin->can('uninstall'), 'Test plugin can install' );
+ok( Koha::Plugins::Handler->run({ class => "Koha::Plugin::Test", method => 'report' }) eq "Koha::Plugin::Test::report", 'Test run plugin report method' );
+
my $metadata = $plugin->get_metadata();
ok( $metadata->{'name'} eq 'Test Plugin', 'Test $plugin->get_metadata()' );