You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
While doing this I noticed that the AugmentProperties processor makes sure to set the oneOf property whenever a ref is set on a nullable === true schema.
I wanted to overwrite this by creating a new processor which would revert this ONLY for schemas based on enums. See implementation:
<?phpdeclare(strict_types=1);
namespaceNelmio\ApiDocBundle\Processors;
useOpenApi\Analysis;
useOpenApi\Generator;
useOpenApi\Processors\ProcessorInterface;
useOpenApi\AnnotationsasOA;
finalclass EnumOneOfToRefProcessor implements ProcessorInterface
{
publicfunction__invoke(Analysis$analysis): void
{
if (\PHP_VERSION_ID < 80100) {
return;
}
$schemas = $analysis->openapi?->components->schemas;
foreach ($schemasas$schema) {
if (!is_array($properties = $schema->properties)) {
continue;
}
foreach ($propertiesas$property) {
if ($property->nullable !== true) {
continue;
}
if (!is_array($property->oneOf)) {
continue;
}
if (count($property->oneOf) !== 1) {
continue;
}
if (!$refSchema = $this->schemaForRef($schemas, $ref = $property->oneOf[0]->ref)) {
continue;
}
if (!$class = $analysis->getContext($refSchema)?->class) {
continue;
}
if (!enum_exists($class)) {
continue;
}
$property->ref = $ref;
$property->oneOf = Generator::UNDEFINED;
}
}
}
/** * Find schema for the given ref. */privatefunctionschemaForRef(array$schemas, string$ref): ?OA\Schema
{
foreach ($schemasas$schema) {
if (OA\Components::ref($schema) === $ref) {
return$schema;
}
}
returnnull;
}
}
I assumed this to work because I though that processors were 'absolute', this seems to not be the case because the AbstractAnnotation class overwrites my changes again while generating the json.
if ('_' == $property[0] || in_array($property, ['ref', 'nullable'])) {
continue;
}
if (!Generator::isDefault($value)) {
$ref[$property] = $value;
}
}
}
Solution
A possible solution could be to modify above highlighted code with this:
// $refif (isset($data->ref)) {
// Only specific https://github.com/OAI/OpenAPI-Specification/blob/3.1.0/versions/3.1.0.md#reference-object$ref = ['$ref' => $data->ref];
if ($this->_context->version === OpenApi::VERSION_3_1_0) {
foreach (['summary', 'description'] as$prop) {
if (property_exists($this, $prop)) {
if (!Generator::isDefault($this->{$prop})) {
$ref[$prop] = $data->{$prop};
}
}
}
}
foreach (get_object_vars($this) as$property => $value) {
if ('_' == $property[0] || in_array($property, ['ref'])) {
continue;
}
if (!Generator::isDefault($value)) {
$ref[$property] = $value;
}
}
$data = (object) $ref;
}
This would make sure to not overwrite our changes from our processor.
The old logic could then be placed inside of an new processor that this package provides.
But then again there might have been a reason why it was not done this way, which I do not know of. I hope hear some thoughts about this and maybe we can find a solution 😄
Your question highlights the fact that for a long time I didn't really have a clue what I was doing in the codebase :)
Over time a lot of changes have been done in the most convenient place but not necessarily the best place.
I agree with you that this type of modification should be the responsibility of a processor. Serialization should not have to deal with this sort of thing.
Maybe we need an OpenApiVersion processor that handles the version specific modifications?
I encountered an issue while trying to create a fix for our generated enums nelmio/NelmioApiDocBundle#2177
While doing this I noticed that the
AugmentProperties
processor makes sure to set theoneOf
property whenever aref
is set on anullable === true
schema.swagger-php/src/Processors/AugmentProperties.php
Lines 172 to 185 in a70a5dc
I wanted to overwrite this by creating a new processor which would revert this ONLY for schemas based on enums. See implementation:
I assumed this to work because I though that processors were 'absolute', this seems to not be the case because the
AbstractAnnotation
class overwrites my changes again while generating the json.swagger-php/src/Annotations/AbstractAnnotation.php
Lines 368 to 386 in a70a5dc
Solution
A possible solution could be to modify above highlighted code with this:
This would make sure to not overwrite our changes from our processor.
The old logic could then be placed inside of an new processor that this package provides.
But then again there might have been a reason why it was not done this way, which I do not know of. I hope hear some thoughts about this and maybe we can find a solution 😄
For now I have simply fallen back to the previous behaviour nelmio/NelmioApiDocBundle#2178
The text was updated successfully, but these errors were encountered: