NAME

RDF::Sesame - Interact with Sesame RDF servers

SYNOPSIS

use RDF::Sesame;

# Connect anonymously to Sesame on localhost port 80
my $sesame = RDF::Sesame->connect;

# or anonymously on a remote Sesame server
$sesame = RDF::Sesame->connect('openrdf.org');

# or explicitly specify the options
$sesame = RDF::Sesame->connect(
   host      => "openrdf.org",
   port      => 80
   directory => "sesame",
   username  => "testuser",
   password  => "opensesame"
) or die "Couldn't connect to Sesame : $RDF::Sesame::errstr\n";

# or explicitly specify using a single URI
$sesame = RDF::Sesame->connect(
   uri => 'http://testuser:opensesame@openrdf.org:80/sesame'
);

my @repos = $sesame->repositories;

# open a repository the easy way
my $vcard  = $sesame->open("vcard");

# or the more flexible way (allowing other named options)
my $museum = $sesame->open(id => "museum");

my $serql = <<END;
   select x, given, family
   from
    {x} vCard:N {n},
    {n} vCard:Given  {given};
        vCard:Family {family}
   using namespace
     vCard = <http://www.w3.org/2001/vcard-rdf/3.0#>
END

my $results = $vcard->select(
    query    => $serql,
    language => "SeRQL"
);

$vcard->query_language("SeRQL");
$results = $vcard->select($serql);

# $results is a Data::Table object (via RDF::Sesame::TableResults)

DESCRIPTION

The RDF::Sesame module implements a wrapper around the RESTful API (HTTP protocol) provided by Sesame http://openrdf.org. It facilitates connecting, adding data and querying a Sesame server from Perl.

RDF::Sesame itself only provides a method for creating a Connection object. See the documentation for RDF::Sesame::Connection, RDF::Sesame::Repository, and RDF::Sesame::TableResults.

STATUS

This module is in beta testing. The algorithms have been tested thoroughly and are stable. The API might change in a few particulars, hopefully in a backwards-compatible manner.

METHODS

connect ( %opts )

Connects to a Sesame server and creates an instance of an RDF::Sesame::Connection object. This object can be used to create an RDF::Sesame::Repository object or (less likely) to execute commands against a Sesame server. Creating an RDF::Sesame::Repository object is the preferred way, so do that.

The HTTP connection to the server is created with Keep-Alive enabled in an attempt to make consecutive requests speedier.

The %opts parameter is a hash of options to use when creating the connection. Below is a list of the currently understood options. If a single scalar is provided to connect(), it will be treated as the host and all other options will use the default values.

host

The host name or address of the sesame server. For example 'openrdf.org' or 'openrdf.org:8080'. It's not a URI.

Default: localhost

port

The port number on which the Sesame server is listening.

Default: 80

directory

The sesame directory on the host. The directory should be specified without leading or trailing '/' characters. However, if those characters are provided, they will be stripped before further processing.

Default: sesame

username

The username to use for logging in to the server. If this option is not specified (or undef), no login will be attempted and only publicly available repositories will be visible.

password

The password to use for logging in to the server. If this option is not supplied but the 'username' option is specified, a password consisting of the empty string will be used to log in.

uri

A URI specifying how to connect to the Sesame server. All of the above options may be specified at once by providing them in the URI in standard format. Here is an example URI

http://username:password@host:port/directory

If any of the parts are not specified, the defaults explained above will be used instead.

timeout

When communicating with the Sesame server, RDF::Sesame usually waits 10 seconds for the server to respond. If there is no response within that time, the server is considered unreachable. This option allows you to change this behavior.

CONFIGURATION AND ENVIRONMENT

RDF::Sesame can generate very limited debugging/profiling output. By setting the environment variable RDFSESAME_DEBUG to a true value, each request to the Sesame server will generate a message on STDERR. Here is a short sample:

Command 0 : Ran login in 30 ms
Command 1 : Ran evaluateTableQuery in 45 ms
Command 2 : Ran evaluateTableQuery in 120 ms

The time value generated with each message is the number of milliseconds it took to process the command including network time, database processing time and response processing time.

COMPATIBILITY

The following table indicates RDF::Sesame's compatibility with different versions of Sesame and different sail implementations.

Sesame 1.2.6 : native - OK
               memory - OK
Sesame 1.2.4 : native - OK
               memory - OK
Sesame 1.2.3 : native - OK
               memory - OK
Sesame 1.2.2 : native - OK
               memory - OK
Sesame 1.2.1 : native - OK
               memory - OK
Sesame 1.2   : native - FAIL (known bug)
               memory - OK
Sesame 1.1.3 : native - OK
               memory - OK

I've not personally tested Sesame versions earlier than 1.1.3 but they may work.

COVERAGE

Test coverage results provided by Devel::Cover

----------------------------------- ------ ------ ------ ------ ------ ------
File                                  stmt   bran   cond    sub   time  total
----------------------------------- ------ ------ ------ ------ ------ ------
lib/RDF/Sesame.pm                    100.0    n/a    n/a  100.0    1.1  100.0
lib/RDF/Sesame/Connection.pm         100.0  100.0  100.0  100.0   20.5  100.0
lib/RDF/Sesame/Repository.pm          96.7   95.9    n/a  100.0    9.0   96.7
lib/RDF/Sesame/Response.pm           100.0  100.0    n/a  100.0   46.4  100.0
lib/RDF/Sesame/TableResult.pm         91.2   82.4    n/a  100.0   23.0   88.7
Total                                 96.2   92.2  100.0  100.0  100.0   95.4
----------------------------------- ------ ------ ------ ------ ------ ------

DEPENDENCIES

A list of all the other modules that this module relies upon, including any restrictions on versions, and an indication whether these required modules are part of the standard Perl distribution, part of the module's distribution, or must be installed separately.

SEE ALSO

RDF::Sesame::Connection
RDF::Sesame::Repository
RDF::Sesame::TableResult

ACKNOWLEDGEMENTS

Southwest Counseling Service for sponsoring the initial development http://swcounseling.org.

AUTHOR

Michael Hendricks <michael@ndrix.com>

LICENSE AND COPYRIGHT

Copyright (c) 2005-2006 Michael Hendricks (<michael@ndrix.com>). All rights reserved.

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