Skip to content

phpetra/oai-pmh-tools

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

oai-pmh-tools - PHP Tools for OAI-PMH

The OaiPmhTools provides a set of classes for both Harvesting data sets from OAI-PMH servers and creating such a server. These tools are framework independent and require nothing more than either lib_xml or curl to be enabled.

For more information on the Archives Initiative Protocol for Metadata Harvesting, please see [the specification on the openarchives.org website]

This set of tools include:

  • An OaiPmhClient that sends requests to the external webservice.
  • A Harvester - first feature once client is finished
  • Build harvester with default mapper
  • @todo build the Discovery / Explorer
  • @todo build the server side of things

Work in progress!!

Installation

Simplest is to add the following to composer.json: But the package is not on packagist yet.

{
    "require": {
        "phpetra/oai-pmh-tools": "dev-master"
    }
}

And then run:

php composer.phar install

Usage

The OaiPmhClient

In order to remain as flexible as possible, the OaiPmhClient comes with two Adapters:

  • One adapter using xml
  • And another one that uses curl to do the remote calls

Both use DOM to parse the xml.

Setting up the client is as simple as:

use OaiPmhTools\Client\XmlClient;

$client = new XmlClient();
// Listing Identifiers
$uri = 'http://data.beeldengeluid.nl/oai-pmh';
$client
    ->setUri($uri)
    ->setMetadataPrefix('oai_dc')
    ->listIdentifiers()

The Harvester

For harvesting data from an OAI-PMH server where you know exactly what you want to retrieve, the configuration and setup is pretty simple: First step is to configure some things:

  • the Harveste can use a mapper and a database... @todo complete this

About

Set of PHP tools for OAI-PMH

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages