forked from loafle/openapi-generator-original
* support symfony6 * fix issues with StrictJsonDeserialization * regenerate samples * add suggestions * update samples * support php 7.4 and symfony 5 * allow versions based on semantic versioning * regenerate sample * change method of determining result types * update samples * describe usage of bundle in symfony app * better documentation * fix duplicate auth methods * do not set namespace for default types * fix UploadedFile type * next try fixing auth * regenerate samples * fix: auth method shall not be duplicated * Revert "fix duplicate auth methods" This reverts commit 0dc418737b1379a30b7f22e7937819ba965c9ddb. * chore: regenerate samples * fix tests * regenerate sample * more fixes for tests * update tests * add kernel shutdown Co-authored-by: Benjamin Haeublein <benjaminh@testing-vm.lan.benjaminh.de> Co-authored-by: Renaud de Chivré <renaud@tahitiwebdesign.com>
124 lines
3.5 KiB
PHP
124 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace OpenAPI\Server\Service;
|
|
|
|
use JMS\Serializer\SerializerBuilder;
|
|
use JMS\Serializer\Naming\CamelCaseNamingStrategy;
|
|
use JMS\Serializer\Naming\SerializedNameAnnotationStrategy;
|
|
use JMS\Serializer\Visitor\Factory\XmlDeserializationVisitorFactory;
|
|
use DateTime;
|
|
use RuntimeException;
|
|
|
|
class JmsSerializer implements SerializerInterface
|
|
{
|
|
protected $serializer;
|
|
|
|
public function __construct()
|
|
{
|
|
$namingStrategy = new SerializedNameAnnotationStrategy(new CamelCaseNamingStrategy());
|
|
$this->serializer = SerializerBuilder::create()
|
|
->setDeserializationVisitor('json', new StrictJsonDeserializationVisitorFactory())
|
|
->setDeserializationVisitor('xml', new XmlDeserializationVisitorFactory())
|
|
->setPropertyNamingStrategy($namingStrategy)
|
|
->build();
|
|
}
|
|
|
|
public function serialize($data, $format)
|
|
{
|
|
return SerializerBuilder::create()->build()->serialize($data, $this->convertFormat($format));
|
|
}
|
|
|
|
public function deserialize($data, $type, $format)
|
|
{
|
|
if ($format == 'string') {
|
|
return $this->deserializeString($data, $type);
|
|
}
|
|
|
|
// If we end up here, let JMS serializer handle the deserialization
|
|
return $this->serializer->deserialize($data, $type, $this->convertFormat($format));
|
|
}
|
|
|
|
private function convertFormat($format)
|
|
{
|
|
switch ($format) {
|
|
case 'application/json':
|
|
return 'json';
|
|
case 'application/xml':
|
|
return 'xml';
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
private function deserializeString($data, $type)
|
|
{
|
|
// Figure out if we have an array format
|
|
if (1 === preg_match('/array<(csv|ssv|tsv|pipes),(int|string)>/i', $type, $matches)) {
|
|
return $this->deserializeArrayString($matches[1], $matches[2], $data);
|
|
}
|
|
|
|
switch ($type) {
|
|
case 'int':
|
|
case 'integer':
|
|
if (is_int($data)) {
|
|
return $data;
|
|
}
|
|
|
|
if (is_numeric($data)) {
|
|
return $data + 0;
|
|
}
|
|
|
|
break;
|
|
case 'string':
|
|
break;
|
|
case 'boolean':
|
|
case 'bool':
|
|
if (strtolower($data) === 'true') {
|
|
return true;
|
|
}
|
|
|
|
if (strtolower($data) === 'false') {
|
|
return false;
|
|
}
|
|
|
|
break;
|
|
case 'DateTime':
|
|
case '\DateTime':
|
|
return new DateTime($data);
|
|
default:
|
|
throw new RuntimeException(sprintf("Type %s is unsupported", $type));
|
|
}
|
|
|
|
// If we end up here, just return data
|
|
return $data;
|
|
}
|
|
|
|
private function deserializeArrayString($format, $type, $data)
|
|
{
|
|
// Parse the string using the correct separator
|
|
switch ($format) {
|
|
case 'csv':
|
|
$data = explode(',', $data);
|
|
break;
|
|
case 'ssv':
|
|
$data = explode(' ', $data);
|
|
break;
|
|
case 'tsv':
|
|
$data = explode("\t", $data);
|
|
break;
|
|
case 'pipes':
|
|
$data = explode('|', $data);
|
|
break;
|
|
default;
|
|
$data = [];
|
|
}
|
|
|
|
// Deserialize each of the array elements
|
|
foreach ($data as $key => $item) {
|
|
$data[$key] = $this->deserializeString($item, $type);
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
}
|