# ================================================================== # 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 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 returns 1 on success, undef on failure with the error message in $GT::Plugins::error. =head2 install_menu C 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 returns 1 on success, undef on failure with the error message in $GT::Plugins::error. =head2 install_options C 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 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