microdata-parser/src/MicrodataParser.php

93 lines
2.3 KiB
PHP

<?php
namespace YusufKandemir\MicrodataParser;
class MicrodataParser
{
protected $dom;
public function __construct(MicrodataDOMDocument $dom)
{
$dom->registerNodeClass(\DOMDocument::class, MicrodataDOMDocument::class);
$dom->registerNodeClass(\DOMElement::class, MicrodataDOMElement::class);
$this->dom = $dom;
}
public function toArray()
{
// Somewhat hacky way to convert deep objects
return json_decode(json_encode($this->extractMicrodata()), true);
}
public function toObject()
{
return $this->extractMicrodata();
}
public function toJSON($options = 0, $depth = 512)
{
return json_encode($this->extractMicrodata(), $options, $depth);
}
protected function extractMicrodata()
{
$result = new \stdClass;
$result->items = [];
foreach ($this->dom->getItems() as $item) {
$result->items[] = $this->getObject($item);
}
return $result;
}
protected function getObject(MicrodataDOMElement $item, $memory = [])
{
$result = new \stdClass;
$memory[] = $item;
$result->type = $item->tokenizeAttribute('itemtype');
// @todo Check if types are valid absolute urls
if ($item->hasAttribute('itemid')) {
$result->id = $item->getAttribute('itemid');
}
// @todo Check if item ids are valid absolute urls or like isbn:xxx
$properties = new \stdClass;
foreach ($item->getProperties() as $element) {
$value = $element->getPropertyValue();
if ($this->isItem($value)) {
foreach ($memory as $memory_item) {
if ($element->isSameNode($memory_item)) {
$value = 'ERROR';
break;
}
}
if ($value != 'ERROR') {
$value = $this->getObject($value, $memory);
}
}
foreach ($element->getPropertyNames() as $name) {
$properties->{$name}[] = $value;
}
}
$result->properties = $properties;
return $result;
}
protected function isItem($element)
{
return $element instanceof MicrodataDOMElement && $element->hasAttribute('itemscope');
}
}