mirror of
https://github.com/werkraum-media/thuecat.git
synced 2025-01-13 22:49:27 +01:00
Daniel Siepmann
bfd4c77a17
Use Symfony components to map incoming JSON onto objects. Those provide a mapping. They can then be used to fetch the data in a common way and insert it into the system. - Handle languages within JsonDecode (normalize incoming data based on language) - Handle Single Value and List of Values within Entities. They will map incoming Data to proper Objects. (We now generally transform during serialization process if target is array but we got single entity) - Add missing tests for existing data. - Finish migration of all existing data, this includes next step - Provide discriminator to ObjectNormalizer to auto detect target class based on "type" property. (Done for now by own registry) - Combine generated object with current structure for import -> generate data array out of it. - Resolve foreign references to existing entities, (images, contentresponsible, etc.)
135 lines
2.9 KiB
PHP
135 lines
2.9 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\Entity\Properties;
|
|
|
|
class Address
|
|
{
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $streetAddress = '';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $addressLocality = '';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $postalCode = '';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $telephone = '';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $faxNumber = '';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $email = '';
|
|
|
|
public function getStreetAddress(): string
|
|
{
|
|
return $this->streetAddress;
|
|
}
|
|
|
|
public function getAddressLocality(): string
|
|
{
|
|
return $this->addressLocality;
|
|
}
|
|
|
|
public function getPostalCode(): string
|
|
{
|
|
return $this->postalCode;
|
|
}
|
|
|
|
public function getTelephone(): string
|
|
{
|
|
return $this->telephone;
|
|
}
|
|
|
|
public function getFaxNumber(): string
|
|
{
|
|
return $this->faxNumber;
|
|
}
|
|
|
|
public function getEmail(): string
|
|
{
|
|
return $this->email;
|
|
}
|
|
|
|
/**
|
|
* @internal for mapping via Symfony component.
|
|
*/
|
|
public function setStreetAddress(string $streetAddress): void
|
|
{
|
|
$this->streetAddress = $streetAddress;
|
|
}
|
|
|
|
/**
|
|
* @internal for mapping via Symfony component.
|
|
*/
|
|
public function setAddressLocality(string $addressLocality): void
|
|
{
|
|
$this->addressLocality = $addressLocality;
|
|
}
|
|
|
|
/**
|
|
* @internal for mapping via Symfony component.
|
|
*/
|
|
public function setPostalCode(string $postalCode): void
|
|
{
|
|
$this->postalCode = $postalCode;
|
|
}
|
|
|
|
/**
|
|
* @internal for mapping via Symfony component.
|
|
*/
|
|
public function setTelephone(string $telephone): void
|
|
{
|
|
$this->telephone = $telephone;
|
|
}
|
|
|
|
/**
|
|
* @internal for mapping via Symfony component.
|
|
*/
|
|
public function setFaxNumber(string $faxNumber): void
|
|
{
|
|
$this->faxNumber = $faxNumber;
|
|
}
|
|
|
|
/**
|
|
* @internal for mapping via Symfony component.
|
|
*/
|
|
public function setEmail(string $email): void
|
|
{
|
|
$this->email = $email;
|
|
}
|
|
}
|