discourse-legacysite-perl/site/slowtwitch.com/cgi-bin/articles/admin/GT/Plugins/Installer.pm
2024-06-17 21:49:12 +10:00

267 lines
7.5 KiB
Perl

# ==================================================================
# Gossamer Threads Module Library - http://gossamer-threads.com/
#
# GT::Plugins
# Author : Alex Krohn
# CVS Info : 087,071,086,086,085
# $Id: Installer.pm,v 1.15 2006/11/22 01:21:14 brewt Exp $
#
# Copyright (c) 2004 Gossamer Threads Inc. All Rights Reserved.
# ==================================================================
#
# Description: A web based admin to install/uninstall plugins.
#
package GT::Plugins::Installer;
# ==================================================================
use strict;
use vars qw/@ISA $ATTRIBS $ERROR_MESSAGE $VERSION $DEBUG/;
use GT::Base;
use GT::Plugins;
use GT::Tar;
$ERROR_MESSAGE = 'GT::Plugins';
$DEBUG = 0;
$VERSION = sprintf "%d.%03d", q$Revision: 1.15 $ =~ /(\d+)\.(\d+)/;
$ATTRIBS = {
plugin_dir => undef,
prog_ver => undef,
prog_user_cgi => undef,
prog_admin_cgi => undef,
prog_images => undef,
prog_libs => undef
};
@ISA = qw/GT::Base/;
sub init {
# ----------------------------------------------------------------
# Load the plugin config file on init() called from GT::Base.
#
my $self = shift;
my $param = $self->common_param(@_);
$self->set($param);
if (! $self->{plugin_dir} or ! -d $self->{plugin_dir}) {
return $self->error('BADARGS', 'FATAL', "missing/invalid plugin dir passed to manager.");
}
$self->{cfg} = GT::Plugins->load_cfg($self->{plugin_dir});
}
# ----------------------------------------------------------------------------------------- #
# Utilities used in Install/Uninstall by Plugins #
# ----------------------------------------------------------------------------------------- #
sub install_hooks {
# -----------------------------------------------------------------
# Register a list of plugin hooks.
#
my ($self, $plugin, $hooks) = @_;
if (ref $hooks ne 'ARRAY') {
return $self->error('BADARGS', 'FATAL', "Usage: $self->install_menu('PLUGINNAME', [['hookname', 'PRE/POST', 'action', status], ...])");
}
if (ref $hooks->[0] ne 'ARRAY') {
$hooks = [ $hooks ];
}
foreach my $hook (@$hooks) {
my ($hookname, $prepost, $action, $status) = @$hook;
if (! ((uc $prepost eq 'PRE') or (uc $prepost eq 'POST'))) {
die "Invalid hook argument. Must be pre/post, not: $prepost";
}
# Allow a hook to be installed as disabled by default, but for backwards compatibility, it has to be a 0 (not just a false value).
$status = (defined $status and $status ne '' and $status == 0) ? 0 : 1;
push @{$self->{cfg}->{$plugin}->{hooks}}, [lc $hookname, uc $prepost, $action, $status];
}
GT::Plugins->save_cfg($self->{plugin_dir}, $self->{cfg});
}
sub install_menu {
# -----------------------------------------------------------------
# Register a list of menu options for a plugin.
#
my ($self, $plugin, $menus) = @_;
if (ref $menus ne 'ARRAY') {
return $self->error('BADARGS', 'FATAL', "Usage: $self->install_menu('PLUGINNAME', [['title', 'url'], ...])");
}
if (ref $menus->[0] ne 'ARRAY') {
$menus = [ $menus ];
}
foreach my $menu (@$menus) {
push @{$self->{cfg}->{$plugin}->{menu}}, $menu;
}
GT::Plugins->save_cfg($self->{plugin_dir}, $self->{cfg});
}
sub install_options {
# -----------------------------------------------------------------
# Register a list of options for a plugin.
#
my ($self, $plugin, $opts, ) = @_;
if (ref $opts ne 'ARRAY') {
return $self->error('BADARGS', 'FATAL', "Usage: $self->install_options('PLUGINNAME', [['name', 'val', 'instructions'] ...])");
}
if (ref $opts->[0] ne 'ARRAY') {
$opts = [ $opts ];
}
foreach my $opt (@$opts) {
exists $self->{cfg}->{$plugin}->{user} or ($self->{cfg}->{$plugin}->{user} = []);
push @{$self->{cfg}->{$plugin}->{user}}, $opt;
}
GT::Plugins->save_cfg($self->{plugin_dir}, $self->{cfg});
}
sub install_registry {
# -----------------------------------------------------------------
# Register a registry item for a plugin.
#
my ($self, $plugin, $opts) = @_;
if (ref $opts ne 'HASH') {
return $self->error('BADARGS', 'FATAL', "Usage: $self->install_options('PLUGINNAME', { key => value, ... })");
}
my $registry = ($self->{cfg}->{$plugin}->{registry} ||= {});
foreach my $key (keys %$opts) {
$registry->{$key} = $opts->{$key};
}
GT::Plugins->save_cfg($self->{plugin_dir}, $self->{cfg});
}
sub uninstall_hooks {
# -----------------------------------------------------------------
# Remove plugins, just a no-op as the config gets deleted.
#
my ($self, $plugin, $hooks) = @_;
return 1;
}
sub uninstall_menu {
# -----------------------------------------------------------------
# Remove menus, no-op as config gets deleted.
#
my ($self, $plugin, $menus) = @_;
return 1;
}
sub uninstall_options {
# -----------------------------------------------------------------
# Remove options, just a no-op as config gets deleted.
#
my ($self, $plugin, $opts) = @_;
return 1;
}
sub uninstall_registry {
# -----------------------------------------------------------------
# Remove registry, just a no-op as config gets deleted.
#
return 1;
}
1;
__END__
=head1 NAME
GT::Plugins::Installer
=head1 SYNOPSIS
$mgr->install_hooks('PluginName', ['hook_name', 'PRE|POST', 'code', status]);
$mgr->install_menu('PluginName', ['menu_name', 'menu_url', 'enabled']);
$mgr->install_options('PluginName', ['option_key', 'option_val', 'instructions']);
=head1 DESCRIPTION
The installer is an object that is passed into plugins during installation.
It provides methods to add hooks, menu options, admin options or copy files
into the users application.
=head2 install_hooks
C<install_hooks> takes as arguments the plugin name and an array of:
=over 4
=item hook_name
The hook you want to override.
=item PRE/POST
Either the string PRE or POST depending on whether the hook should be run
before the main code, or after.
=item code
The name of the code to run. It should be Plugins::PACKAGE::YourPluginName::function.
Where PACKAGE is the name of the Gossamer Product the plugin is for. For example
Plugins::GMail::Wap::header
=item status
Whether or not the hook will be enabled or disabled. For backwards
compatibility, if this option is set to anything but '0' then the hook will be
enabled.
=back
C<install_hooks> returns 1 on success, undef on failure with the error
message in $GT::Plugins::error.
=head2 install_menu
C<install_menu> takes as arguments the plugin name and an array of:
=over 4
=item menu_name
The name that will show up in the admin menu.
=item menu_url
The URL for the menu option.
=item enabled
Either true or false depending on whether the menu option should be shown.
=back
C<install_menu> returns 1 on success, undef on failure with the error
message in $GT::Plugins::error.
=head2 install_options
C<install_options> takes as arguments the plugin name and an array of:
=over 4
=item option_key
This is the key, and is used when accessing the options hash.
=item option_value
This is the default value.
=item instructions
A string instruction users on what the plugin does.
=back
C<install_options> returns 1 on success, undef on failure with the error
message in $GT::Plugins::error.
=head1 COPYRIGHT
Copyright (c) 2004 Gossamer Threads Inc. All Rights Reserved.
http://www.gossamer-threads.com/
=head1 VERSION
Revision: $Id: Installer.pm,v 1.15 2006/11/22 01:21:14 brewt Exp $
=cut