NAME
    JSON::GRDDL - transform JSON to RDF

SYNOPSIS
     # Low-Level Interface
     #
     my $grddl = JSON::GRDDL->new;
     my @transformations = $grddl->discover($jsondoc, $baseuri);
     foreach my $trans (@transformations)
     {
       my $model = $grddl->transform_by_uri($jsondoc, $baseuri, $trans);
       # $model is an RDF::Trine::Model
     }

     # High-Level Interface
     #
     my $grddl = JSON::GRDDL->new;
     my $model = $grddl->data($jsondoc, $baseuri);
     # $model is an RDF::Trine::Model

DESCRIPTION
    This module implements jsonGRDDL, a port of GRDDL concepts from XML to
    JSON.

    jsonGRDDL is described at <http://buzzword.org.uk/2008/jsonGRDDL/spec>.

    This module attempts to provide a similar API to XML::GRDDL but differs in
    some respects.

  Constructor
    `JSON::GRDDL->new`
        The constructor accepts no parameters and returns a JSON::GRDDL
        object.

  Methods
    `$grddl->ua`
    `$grddl->ua($ua)`
        Get/set an LWP::UserAgent object for HTTP requests.

    `$grddl->data($json, $base, %options)`
        This is usually what you want to call. It's a high-level method that
        does everything for you and returns the RDF you wanted. $json is the
        raw JSON source of the document, or an equivalent Perl
        hashref/arrayref structure. $base is the base URI for resolving
        relative references.

        Returns an RDF::Trine::Model.

    `$grddl->discover($json, $base, %options)`
        You only need to call this method if you're doing something unusual.

        Processes the JSON document to discover the transformation associated
        with it. $json is the raw JSON source of the document, or an
        equivalent Perl hashref/arrayref structure. $base is the base URI for
        resolving relative references.

        Returns a list of URLs as strings.

    `$grddl->transform_by_uri($json, $base, $transformation, %options)`
        You only need to call this method if you're doing something unusual.

        Transforms a JSON document into RDF using a JsonT transformation,
        specified by URI. $json is the raw JSON source of the document, or an
        equivalent Perl hashref/arrayref structure. $base is the base URI for
        resolving relative references. $transformation is the URI for the
        JsonT transformation.

        Returns an RDF::Trine::Model.

    `$grddl->transform_by_jsont($json, $base, $code, $name, %options)`
        You only need to call this method if you're doing something unusual.

        Transforms a JSON document into RDF using a JsonT transformation,
        specified as a Javascript code, variable name pair. $json is the raw
        JSON source of the document, or an equivalent Perl hashref/arrayref
        structure. $base is the base URI for resolving relative references.
        $code and $name must be suitable for passing to the `new` constructor
        from the JSON::T package.

        Returns an RDF::Trine::Model.

BUGS
    Please report any bugs to <http://rt.cpan.org/>.

SEE ALSO
    Specification: <http://buzzword.org.uk/2008/jsonGRDDL/spec>.

    Related modules: JSON, JSON::T, JSON::Path, JSON::Hyper, JSON::Schema,
    XML::GRDDL.

    <http://www.perlrdf.org/>.

    This module is derived from Swignition
    <http://buzzword.org.uk/swignition/>.

AUTHOR
    Toby Inkster <tobyink@cpan.org>.

COPYRIGHT AND LICENCE
    Copyright 2008-2011 Toby Inkster.

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

DISCLAIMER OF WARRANTIES
    THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
    WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
    MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.