NAME
Footprintless::Plugin - The base class for footprintless plugins
VERSION
version 1.22
DESCRIPTION
This class serves as a base class for plugins. It defines the mandatory interface that a plugin must implement. Plugins add methods to the factory itself at runtime. For example:
package Foo::Plugin;
use parent qw(Footprintless::Plugin);
sub foo {
require Foo;
return Foo->new();
}
sub factory_methods {
my ($self) = @_;
return {
foo => sub {
return $self->foo(@_);
}
}
}
package Foo;
sub new() {
return bless({}, shift);
}
sub bar {
print("BAR");
}
Then they can be registered with a factory instance:
$factory->register_plugin(Foo::Plugin->new());
Or, they can be registered via configuration in the footprintless.plugins
entity:
# $FPL_HOME/config/footprintless.pm
return {
plugins => [
'Foo::Plugin',
'Bar::Plugin'
],
'Foo::Plugin' => {
# optional config
}
'Bar::Plugin' => {
# optional config
}
};
Then you can use the methods directly on the footprintless instance:
my $footprintless = Footprintless->new();
my $foo = $footprintless->foo();
If a key with the same name as the plugin is present in the footprintless
entity, then the entire hashref will be set as $self-
{config}> on the plugin instance during construction. You can then override the _init()
method to do configuration based initialization.
If you want to add commands, just add a module under the package returned by command_packages (defaults to ref($self) . '::Command'
):
package Foo::Plugin::Command::foo
use Footprintless::App -command;
sub execute {
my ($self, $opts, $args) = @_;
my $foo = $self->app()->footprintless()->foo();
$foo->bar();
}
Then your command will be availble from the fpl command:
$> fpl foo
BAR
CONSTRUCTORS
new()
Creates a new plugin.
METHODS
command_packages()
Returns a list of packages to scan for commands.
factory_methods()
Returns a hash full of factory methods. The key will be used as the method name that gets registered with the factory. Its value must be a reference to a sub.
AUTHOR
Lucas Theisen <lucastheisen@pastdev.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2016 by Lucas Theisen.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
SEE ALSO
Please see those modules/websites for more information related to this module.