NAME
RDF::Query::Client - Get data from W3C SPARQL Protocol 1.0 servers
VERSION
0.03
SYNOPSIS
use RDF::Query::Client;
my $query = new RDF::Query::Client ("SELECT * WHERE {?s ?p ?o. ?o ?p ?s.}");
my $iterator = $query->execute('http://example.com/sparql');
while (my $row = $iterator->next) {
print $row->{'s'}->as_string;
}
METHODS
new ( $query, \%opts )
-
Returns a new RDF::Query::Client object for the specified
$query
. The object's interface is designed to be roughly compatible with RDF::Query objects. The query language is always 'sparql'.Options include:
* UserAgent - an LWP::UserAgent to handle HTTP requests.
execute ( $endpoint, \%opts )
-
$endpoint
is a URI object or string containing the endpoint URI to be queried.Options include:
* UserAgent - an LWP::UserAgent to handle HTTP requests. * QueryMethod - 'GET', 'POST' or undef (automatic). * QueryParameter - defaults to 'query'. * AuthUsername - HTTP Basic authorization. * AuthPassword - HTTP Basic authorization. * Headers - additional headers to include (hashref). * Parameters - additional GET/POST fields to include (hashref).
Returns undef on error; an RDF::Trine::Iterator if called in a scalar context; an array obtained by calling
get_all
on the iterator if called in list context. get ( $endpoint, \%opts )
-
Executes the query using the specified endpoint, and returns the first matching row as a LIST of values. Takes the same arguments as
execute()
. as_sparql ()
-
Returns the query as a string in the SPARQL syntax.
useragent ()
-
Returns the LWP::UserAgent object used for retrieving web content.
http_response ()
-
Returns the last HTTP Response the client experienced.
error ()
-
Returns the last error the client experienced.
SECURITY
The <execute()
> and <get()
> methods allow AuthUsername and AuthPassword options to be passed to them for HTTP Basic authentication. For more complicated Authentication (Digest, OAuth, Windows, etc), it is also possible to pass these methods a customised LWP::UserAgent.
If you have the Crypt::SSLeay package installed, requests to HTTPS endpoints should work. It's possible to specify a client X.509 certificate (e.g. for FOAF+SSL authentication) by setting particular environment variables. See Crypt::SSLeay documentation for details.
BUGS
Probably.
SEE ALSO
http://www.w3.org/TR/rdf-sparql-protocol/
http://www.w3.org/TR/rdf-sparql-query/
http://www.perlrdf.org/
AUTHOR
Toby Inkster, <tobyink@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2009 by Toby Inkster
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.6.0 or, at your option, any later version of Perl 5 you may have available.