sub new {
my $class = shift;
my $self = {'_DEBUG' => 0,
- '_OUT' => sub {printf(@_)},
- '_CONNECTORS' => sub { return ({ 'name' => 'direct',
- 'schemas' => {} }) },
'_CONNECTOR' => undef,
+ API => {
+ io => sub { printf(@_) },
+ connectors => sub { return ({ 'name' => 'direct',
+ 'schemas' => {} }) },
+ },
@_,
};
+ # Add the 'enabled' property to all modules
+ $self->{_PARAMS}->{enabled} = [1, 'Whether the module is enabled'];
bless($self, $class);
$self->_prepare_parameters();
$data[0] = "(" . ref($self) . ") " . $data[0];
- $self->{'_OUT'}(@data);
+ $self->{_API}->{io}->(@data);
}
sub debug {
}
}
-sub setio {
- my $self = shift;
- my $io = shift;
-
- $self->{'_OUT'} = $io;
-}
-
sub getconfstr {
my $self = shift;
my $s = 'Options for ' . $self->{'NAME'} . ":\n";
sub connectors {
my $self = shift;
- return $self->{'_CONNECTORS'}->();
+ return $self->{_API}->{connectors}->();
}
sub selectconn {
$self->{'_CONNECTOR'} = shift;
}
-sub setconn {
+#
+# Register a callbacks into the core API to the plugin.
+# Example of those are config getter/setters and IO functions
+# The API is a hash reference containing subroutine references.
+#
+# After the API is registered an attempt is made to load the config
+# (or set defaults if config values are not found)
+#
+sub register_api {
my $self = shift;
+ my $api = shift;
- $self->{'_CONNECTORS'} = shift;
+ $self->{_API} = $api;
}
1;