NAME
Net::DigitalNZ - Perl interface to digitalnz.org 's open data api.
DESCRIPTION
The metadata available through DigitalNZ comes from content providers across the New Zealand cultural and heritage, broadcasting, education, and government sectors; as well as local community sources and individuals.
You will need to obtain your own API key from http://digitalnz.org
SYNOPSIS
use Net::DigitalNZ;
my $query = 'Waitangi';
my $api_key = 'get your own api key';
my $searcher = Net::DigitalNZ->new(api_key => $api_key);
my $results = $searcher->search($query);
METHODS
search
The search records API call is passed a search query and returns a corresponding result set
# simple query
my $results = $searcher->search($query);
# more complicated query
my $results = $searcher->search($query, {key => value});
Parameters
- num_results
-
the number of results the user wishes returned
- start
-
the offset from which the result list should start
- sort
-
the field upon which results are sorted. If sort_field isn't specified the results are sorted by relevance. The sort_field must be one of: category, content_provider, date, syndication_date, title
- direction
-
the direction in which the results are sorted. Can only be used in conjunction with the sort field and must be either asc or desc. If not specified, sort_direction defaults to asc
- facets
-
a list of facet fields to include in the output. See the note on facets below for more information.
- facet_num_results
-
the number of facet results to include. Only used if the facets parameter is specified, and defaults to 10.
- facet_start
-
the offset from which the facet value list should start. Only used if the facets parameter is specified, and defaults to 0.
Example
use Net::DigitalNZ;
my $query = 'Waitangi';
my $api_key = 'get your own api key from http://digitalnz.org';
my $searcher = Net::DigitalNZ->new(api_key => $api_key);
my $results = $searcher->search($query, {
start=>10,
num_results => 2}
);
print $results->{result_count} . " items found\n";
foreach my $r (@{ $results->{results} } ) {
print $r->{id} . ': '. $r->{title} ."\n";
}
More info at http://www.digitalnz.org/developer/api-docs/search-records
Response elements
The search results will return the following elements:
- num_results_requested
-
the value of the num_results parameter sent to the API method
- result_count
-
the total number of results matching this search
- start
-
the value of the start parameter sent to the API method
- results
-
the search results data. The results element will contain 0 or more result elements, each containing the following elements:
- category
-
a string containing one or more category names separated by a comma (e.g. Images, Web pages)
- content_provider
-
the institution holding the content to which the record refers
- date
-
a date associated with the record (e.g. 1996-01-01T00:00:00.000Z). This field may be empty
- description
-
text describing the record
- display_url
-
the url for the content on the content provider's website
- id
-
the internal DigitalNZ identifier (used by the Get Metadata API)
- metadata-url
-
the url to the DigitalNZ API method that will return the full metadata for the record
- source-url
-
the url that will redirect users directly to the content_url
- thumbnail-url
-
the url of for a thumbnail image of the content to which the record refers. This field may be empty.
- facets
-
the facet result data (if requested). The facets element will contain one facet-field element corresponding to each facet requested. Each facet-field element contains a sorted list of value elements that are made up of a name and num-results element. See the note below for more information on facets.
LICENCE AND COPYRIGHT
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See perlartistic.
VERSION CONTROL
http://github.com/Br3nda/perl-net-digitalnz/tree/master
AUTHOR
Brenda Wallace <brenda@wallace.net.nz> http://br3nda.com
Based heavily on Net::Twitter by Chris Thompson
DISCLAIMER OF WARRANTY
BECAUSE THIS SOFTWARE IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE SOFTWARE, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE SOFTWARE "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE SOFTWARE IS WITH YOU. SHOULD THE SOFTWARE PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR, OR CORRECTION.
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE SOFTWARE AS PERMITTED BY THE ABOVE LICENCE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE SOFTWARE (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE SOFTWARE TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.