SDK for working against Bokbasen's Metadata API. Currently only exports are supported.
The SDK assumes working knowledge of the API, see documentation: https://bokbasen.jira.com/wiki/spaces/api/pages/61964298/Metadata
This SDK requires the Bokbasen API Client, see php-api-client for details on how to implement.
All code examples below assumes that this variable exists:
<?php
use Bokbasen\Auth\Login;
use Bokbasen\ApiClient\Client;
$auth = Login('username', 'password');
$client = new Client($auth);
?>
Use auth object and set your subscription when creating the export object (subscription is based on your contract with Bokbasen. basic, extended or school)
<?php
use Bokbasen\Metadata\Export\Onix;
$onixClient = new Onix($client, Onix::URL_PROD, Onix::SUBSCRIPTION_EXTENDED);
?>
<?php
$onixAsString = $onixClient->getByISBN('9788276749557');
?>
This is only used when you do not have a valid next token. Given filename will be appended until all pages are fetched (if $downloadAllPages === true)
<?php
$nextToken = $onixClient->downloadAfter(new \DateTime('2017-01-01'),'/onixFolder/');
//Save next token for later use
?>
Use $nextToken to get all changes since last execution
<?php
//Loop to get all pages
$morePages = true;
while($morePages){
$morePages = $onixClient->downloadNext($nextToken,'/onixFolder/');
$nextToken = $onixClient->getLastNextToken();
}
//Save next token for later use
?>
If you do not want to use the SDK to write files for you, use the following methods to get the full Response object for each request. This means you need to implement the header parsing logic yourself.
<?php
$response = $onixClient->getAfter(new \DateTime('2017-01-01'));
//Implement your own parsing here and get token from header
//Use token to get more pages
$response = $onixClient->getNext($token);
?>
Object reports has a similar process as ONIX download when it comes to paging. The SDK abstracts the report aspect and download the actual files for you.
This is only used when you do not have a valid next token.
<?php
$nextToken = $objectClient->downloadAfter(new \DateTime('2017-10-01'),'/pathForObjects/');
//Save next token for later use
?>
Use $nextToken to get all changes since last execution
<?php
//Loop to get all pages, each page will be stored as separate file
$morePages = true;
while($morePages){
$morePages = $onixClient->downloadNext($nextToken,'/pathForObjects/');
$nextToken = $onixClient->getLastNextToken();
}
//Save next token for later use
?>
<?php
//Only download spesific types of objects
$nextToken = $objectClient->downloadAfter(new \DateTime('2017-10-01'),'/pathForObjects/',[\Bokbasen\Metadata\Export\Object::OBJECT_TYPE_AUDIO_SAMPLE,\Bokbasen\Metadata\Export\Object::OBJECT_COVER_IMAGE_SMALL]);
//you can also download for spesific ISBNs ($downloadAllPages must be true for this to work, and ensure to set a old date)
$objectClient->downloadAfter(new \DateTime('1950-01-01'),'/pathForObjects/',[\Bokbasen\Metadata\Export\Object::OBJECT_TYPE_AUDIO_SAMPLE,\Bokbasen\Metadata\Export\Object::OBJECT_COVER_IMAGE_SMALL],true,['9788251824491','9788215012520']);
?>