NAME
RDF::LinkedData - A simple Linked Data implementation
VERSION
Version 0.44
SYNOPSIS
For just setting this up and get it to run, you would just use the linked_data.psgi
script in this distribution. The usage of that is documented in Plack::App::RDF::LinkedData. If you want to try and use this directly, you'd do stuff like:
my $ld = RDF::LinkedData->new(store => $config->{store},
endpoint_config => $config->{endpoint},
base_uri => $config->{base_uri}
);
$ld->namespaces($config->{namespaces}) if ($config->{namespaces});
$ld->request($req);
return $ld->response($uri)->finalize;
See Plack::App::RDF::LinkedData for a complete example.
METHODS
new ( store => $store, model => $model, base_uri => $base_uri, hypermedia => 1, namespaces_as_vocabularies => 1, request => $request, endpoint_config => $endpoint_config )
-
Creates a new handler object based on named parameters, given a store config (recommended usage is to pass a hashref of the type that can be passed to RDF::Trine::Store->new_with_config, but a simple string can also be used) or model and a base URI. Optionally, you may pass a Plack::Request object (must be passed before you call
content
) and anendpoint_config
hashref if you want to have a SPARQL Endpoint running using the recommended module RDF::Endpoint.This module can also provide additional triples to turn the respons into a hypermedia type. If you don't want this, set the
hypermedia
argument to false. Currently this entails setting the SPARQL endpoint and vocabularies used using the VoID vocabulary. The latter is very limited at present, all it'll do is use the namespaces if you havenamespaces_as_vocabularies
enabled, which it is by default. BUILD
-
Called by Moose to initialize an object.
model
-
Returns the RDF::Trine::Model object.
base_uri
-
Returns or sets the base URI for this handler.
request ( [ $request ] )
-
Returns the Plack::Request object if it exists or sets it if a Plack::Request object is given as parameter.
etag
-
Returns an Etag suitable for use in a HTTP header
- namespaces ( { skos => 'http://www.w3.org/2004/02/skos/core#', dct => 'http://purl.org/dc/terms/' } )
-
Gets or sets the namespaces that some serializers use for pretty-printing.
response ( $uri )
-
Will look up what to do with the given URI object and populate the response object.
helper_properties ( )
-
Returns the RDF::Helper::Properties object if it exists or sets it if a RDF::Helper::Properties object is given as parameter.
type
-
Returns or sets the type of result to return, i.e.
page
, in the case of a human-intended page ordata
for machine consumption, or an empty string if it is an actual resource URI that should be redirected. my_node
-
A node for the requested URI. This node is typically used as the subject to find which statements to return as data. This expects to get a URI object containing the full URI of the node.
count ( $node)
-
Returns the number of statements that has the $node as subject, or all if $node is undef.
content ( $node, $type, $endpoint_path)
-
Will return the a hashref with content for this URI, based on the $node subject, and the type of node, which may be either
data
orpage
. In the first case, an RDF document serialized to a format set by content negotiation. In the latter, a simple HTML document will be returned. Finally, you may pass the endpoint path if it is available. The returned hashref has two keys:content_type
andbody
. The former is self-explanatory, the latter contains the actual content.One may argue that a hashref with magic keys should be a class of its own, and for that reason, this method should be considered "at risk". Currently, it is only used in one place, and it may be turned into a private method, get passed the Plack::Response object, removed altogether or turned into a role of its own, depending on the actual use cases that surfaces in the future.
endpoint ( [ $endpoint ] )
-
Returns the RDF::Endpoint object if it exists or sets it if a RDF::Endpoint object is given as parameter. In most cases, it will be created for you if you pass a
endpoint_config
hashref to the constructor, so you would most likely not use this method.
AUTHOR
Kjetil Kjernsmo, <kjetilk@cpan.org>
BUGS
Please report any bugs using github
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc RDF::LinkedData
The perlrdf mailing list is the right place to seek help and discuss this module:
http://lists.perlrdf.org/listinfo/dev
TODO
Use IO::Handle streams when they become available from the serializers.
Figure out what needs to be done to use this code in other frameworks, such as Magpie.
Make it read-write hypermedia.
Use a environment variable for config on the command line?
ACKNOWLEDGEMENTS
This module was started by Gregory Todd Williams <gwilliams@cpan.org>
for RDF::LinkedData::Apache, but has been almost totally rewritten.
COPYRIGHT & LICENSE
Copyright 2010 Gregory Todd Williams and ABC Startsiden AS, 2010-2012 Kjetil Kjernsmo
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.