* @date 2017-01-03 * * @license LGPLv3 * @url * * PdfParser is a pdf library written in PHP, extraction oriented. * Copyright (C) 2017 - Sébastien MALOT * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. * If not, see . */ namespace Smalot\PdfParser; use Smalot\PdfParser\Element\ElementArray; use Smalot\PdfParser\Element\ElementMissing; use Smalot\PdfParser\Element\ElementStruct; use Smalot\PdfParser\Element\ElementXRef; /** * Class Header */ class Header { /** * @var Document */ protected $document = null; /** * @var Element[] */ protected $elements = null; /** * @param Element[] $elements list of elements * @param Document $document document */ public function __construct($elements = [], Document $document = null) { $this->elements = $elements; $this->document = $document; } public function init() { foreach ($this->elements as $element) { if ($element instanceof Element) { $element->init(); } } } /** * Returns all elements. */ public function getElements() { foreach ($this->elements as $name => $element) { $this->resolveXRef($name); } return $this->elements; } /** * Used only for debug. * * @return array */ public function getElementTypes() { $types = []; foreach ($this->elements as $key => $element) { $types[$key] = \get_class($element); } return $types; } /** * @param bool $deep * * @return array */ public function getDetails($deep = true) { $values = []; $elements = $this->getElements(); foreach ($elements as $key => $element) { if ($element instanceof self && $deep) { $values[$key] = $element->getDetails($deep); } elseif ($element instanceof PDFObject && $deep) { $values[$key] = $element->getDetails(false); } elseif ($element instanceof ElementArray) { if ($deep) { $values[$key] = $element->getDetails(); } } elseif ($element instanceof Element) { $values[$key] = (string) $element; } } return $values; } /** * Indicate if an element name is available in header. * * @param string $name The name of the element * * @return bool */ public function has($name) { return \array_key_exists($name, $this->elements); } /** * @param string $name * * @return Element|PDFObject */ public function get($name) { if (\array_key_exists($name, $this->elements)) { return $this->resolveXRef($name); } return new ElementMissing(); } /** * Resolve XRef to object. * * @param string $name * * @return Element|PDFObject * * @throws \Exception */ protected function resolveXRef($name) { if (($obj = $this->elements[$name]) instanceof ElementXRef && null !== $this->document) { /** @var ElementXRef $obj */ $object = $this->document->getObjectById($obj->getId()); if (null === $object) { return new ElementMissing(); } // Update elements list for future calls. $this->elements[$name] = $object; } return $this->elements[$name]; } /** * @param string $content The content to parse * @param Document $document The document * @param int $position The new position of the cursor after parsing * * @return Header */ public static function parse($content, Document $document, &$position = 0) { /* @var Header $header */ if ('<<' == substr(trim($content), 0, 2)) { $header = ElementStruct::parse($content, $document, $position); } else { $elements = ElementArray::parse($content, $document, $position); $header = new self([], $document); if ($elements) { $header = new self($elements->getRawContent(), null); } } if ($header) { return $header; } // Build an empty header. return new self([], $document); } }