mirror of
https://github.com/werkraum-media/thuecat.git
synced 2025-01-08 20:26:13 +01:00
Daniel Siepmann
592269baa8
Catch the exception and return null. That is already a possible return type which should be handled by callers. Add test case with referenced 404 image.
105 lines
3 KiB
PHP
105 lines
3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/*
|
|
* Copyright (C) 2021 Daniel Siepmann <coding@daniel-siepmann.de>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* 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 General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301, USA.
|
|
*/
|
|
|
|
namespace WerkraumMedia\ThueCat\Domain\Import;
|
|
|
|
use WerkraumMedia\ThueCat\Domain\Import\EntityMapper\EntityRegistry;
|
|
use WerkraumMedia\ThueCat\Domain\Import\EntityMapper\JsonDecode;
|
|
use WerkraumMedia\ThueCat\Domain\Import\Entity\Properties\ForeignReference;
|
|
use WerkraumMedia\ThueCat\Domain\Import\Importer\FetchData;
|
|
use WerkraumMedia\ThueCat\Domain\Import\Importer\FetchData\InvalidResponseException;
|
|
|
|
/**
|
|
* Can be used to resolve foreign references.
|
|
*
|
|
* The reference will be resolved and returned as entity.
|
|
* It will not be imported!
|
|
* Use Importer instead to import foreign references.
|
|
*/
|
|
class ResolveForeignReference
|
|
{
|
|
/**
|
|
* @var FetchData
|
|
*/
|
|
private $fetchData;
|
|
|
|
/**
|
|
* @var EntityRegistry
|
|
*/
|
|
private $entityRegistry;
|
|
|
|
/**
|
|
* @var EntityMapper
|
|
*/
|
|
private $entityMapper;
|
|
|
|
public function __construct(
|
|
FetchData $fetchData,
|
|
EntityRegistry $entityRegistry,
|
|
EntityMapper $entityMapper
|
|
) {
|
|
$this->fetchData = $fetchData;
|
|
$this->entityRegistry = $entityRegistry;
|
|
$this->entityMapper = $entityMapper;
|
|
}
|
|
|
|
public function resolve(
|
|
ForeignReference $foreignReference,
|
|
string $language
|
|
): ?object {
|
|
try {
|
|
$jsonLD = $this->fetchData->jsonLDFromUrl($foreignReference->getId());
|
|
} catch (InvalidResponseException $e) {
|
|
return null;
|
|
}
|
|
|
|
$jsonEntity = $jsonLD['@graph'][0] ?? null;
|
|
if ($jsonEntity === null) {
|
|
return null;
|
|
}
|
|
|
|
$targetEntity = $this->entityRegistry->getEntityByTypes($jsonEntity['@type']);
|
|
if ($targetEntity === '') {
|
|
return null;
|
|
}
|
|
|
|
return $this->entityMapper->mapDataToEntity(
|
|
$jsonEntity,
|
|
$targetEntity,
|
|
[
|
|
JsonDecode::ACTIVE_LANGUAGE => $language,
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param ForeignReference[] $foreignReferences
|
|
* @return string[]
|
|
*/
|
|
public static function convertToRemoteIds(array $foreignReferences): array
|
|
{
|
|
return array_map(function (ForeignReference $reference) {
|
|
return $reference->getId();
|
|
}, $foreignReferences);
|
|
}
|
|
}
|