NAME

DBD::Sys - System tables interface via DBI

SYNOPSIS

use DBI;
my $dbh = DBI->connect('DBI::Sys:');
my $st  = $dbh->prepare('select distinct * from filesystems join filesysdf on mountpoint');
my $num = $st->execute();
if( $num > 0 )
{
    while( my $row = $st->fetchrow_hashref() )
    {
        # ...
    }
}

DESCRIPTION

DBD::Sys is a so called database driver for DBI designed to request information from system tables using SQL. It's based on SQL::Statement as SQL engine and allows to be extended by DBD::Sys::Plugins.

Prerequisites

Of course, a DBD requires DBI to run. Further, SQL::Statement as SQL engine is required, Module::Pluggable to manage the plugin's and Module::Build for installation. Finally, to speed up some checks, Params::Util is needed.

All these modules are mandatory and DBD::Sys will fail when they are not available.

To request system information, existing modules from CPAN are used - there are available ones to provide access to some system tables. These modules are optional, but recommended. It wouldn't make much sense to use DBD::Sys without the ability to access the tables from the (operating) system.

To get an overview which dependencies are there, please check the plugins or take a look into META.yml.

USAGE

Installation

We chose Module::Build installation, because not every system has a suitable make utility - but at least everyone who's using perl modules has a running perl. So installing can be done after extracting

gzip -dc DBD-Sys-${VERSION}.tar.gz | tar xvf -

without too much extra effort:

1  cd DBD-Sys-${VERSION}
2  perl Build.PL
3  ./Build
4  ./Build test
5  ./Build install

If you want to skip the tests (not recommended), you can skip over lines 3 and 4.

Fetching data

To retrieve data, you can use the following example:

        my $dbh = DBI->connect('DBI:Sys:');
        $st  = $dbh->prepare( 'SELECT DISTINCT username, uid FROM pwent WHERE username=?' );
        $num = $st->execute(getlogin() || $ENV{USER} || $ENV{USERNAME});
	while( $row = $st->fetchrow_hashref() )
	{       
	    printf( "Found result row: uid = %d, username = %s\n", $row->{uid}, $row->{username} );
	}       

Error handling

Following soon...

Metadata

Not yet implemented, but following soon: Block-Sizing, LsoF, Directories, etc.

Restrictions

e.g. No modifying of system tables ...

BUGS & LIMITATIONS

This module does not support any changes to the provided tables in order to prevent inconsistant data.

AUTHOR

Jens Rehsack			Alexander Breibach
CPAN ID: REHSACK
rehsack@cpan.org			alexander.breibach@googlemail.com
http://www.rehsack.de/		http://...

COPYRIGHT

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

The full text of the license can be found in the LICENSE file included with this module.

SUPPORT

Free support can be requested via regular CPAN bug-tracking system at http://rt.cpan.org/NoAuth/Bugs.html?Dist=DBD-Sys. There is no guaranteed reaction time or solution time. It depends on business load. That doesn't mean that ticket via rt aren't handles as soon as possible, that means that soon depends on how much I have to do.

Business and commercial support should be aquired from the authors via preferred freelancer agencies.

SEE ALSO

perl(1), DBI, Module::Build, Module::Pluggable, Params::Util, SQL::Statement.