-
-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #41 from veewee/attribute-type-names
Prefix local types with parent type-name
- Loading branch information
Showing
12 changed files
with
274 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
52 changes: 52 additions & 0 deletions
52
src/Metadata/Converter/Types/Detector/AttributeDeclaringParentTypeDetector.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
<?php declare(strict_types=1); | ||
|
||
namespace Soap\WsdlReader\Metadata\Converter\Types\Detector; | ||
|
||
use GoetasWebservices\XML\XSDReader\Schema\Attribute\AttributeContainer; | ||
use GoetasWebservices\XML\XSDReader\Schema\Attribute\AttributeItem; | ||
use GoetasWebservices\XML\XSDReader\Schema\Item; | ||
use GoetasWebservices\XML\XSDReader\Schema\SchemaItem; | ||
use GoetasWebservices\XML\XSDReader\Schema\Type\Type; | ||
use Psl\Option\Option; | ||
use function Psl\Option\none; | ||
use function Psl\Option\some; | ||
|
||
final class AttributeDeclaringParentTypeDetector | ||
{ | ||
/** | ||
* This class detects the declaring parent type of an attribute. | ||
* It can be used together with the ParentContext and works as followed | ||
* | ||
* - If the parent is an AttributeContainer, it will check if the parent has the attribute | ||
* - If the parent is not declaring the attribute, it will check if the parent is extending another type and test this extended type. | ||
* | ||
* @return Option<Type> | ||
*/ | ||
public function __invoke(AttributeItem $item, ?SchemaItem $parent): Option | ||
{ | ||
$parent = match(true) { | ||
$parent instanceof Item => $parent->getType(), | ||
default => $parent, | ||
}; | ||
|
||
if (!$parent instanceof Type) { | ||
return none(); | ||
} | ||
|
||
if ($parent instanceof AttributeContainer) { | ||
foreach ($parent->getAttributes() as $parentAttribute) { | ||
if ($parentAttribute->getName() === $item->getName()) { | ||
/** @var Option<Type> */ | ||
return some($parent); | ||
} | ||
} | ||
} | ||
|
||
$extensionBase = $parent->getExtension()?->getBase(); | ||
if ($extensionBase) { | ||
return $this->__invoke($item, $extensionBase); | ||
} | ||
|
||
return none(); | ||
} | ||
} |
34 changes: 34 additions & 0 deletions
34
src/Metadata/Converter/Types/Detector/AttributeTypeNameDetector.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
<?php declare(strict_types=1); | ||
|
||
namespace Soap\WsdlReader\Metadata\Converter\Types\Detector; | ||
|
||
use GoetasWebservices\XML\XSDReader\Schema\Attribute\AttributeItem; | ||
use GoetasWebservices\XML\XSDReader\Schema\Attribute\AttributeSingle; | ||
use GoetasWebservices\XML\XSDReader\Schema\Type\Type; | ||
use Psl\Option\Option; | ||
use Soap\WsdlReader\Metadata\Converter\Types\ParentContext; | ||
use function Psl\Option\from_nullable; | ||
|
||
final class AttributeTypeNameDetector | ||
{ | ||
public function __invoke(AttributeItem $attribute, ParentContext $parentContext): string | ||
{ | ||
$attributeType = $attribute instanceof AttributeSingle ? $attribute->getType() : null; | ||
$attributeRestriction = $attributeType?->getRestriction(); | ||
$attributeTypeName = $attributeType?->getName(); | ||
$attributeRestrictionName = ($attributeRestriction && !$attributeRestriction->getChecks()) ? $attributeRestriction->getBase()?->getName() : null; | ||
|
||
$typeName = $attributeTypeName ?: ($attributeRestrictionName ?: $attribute->getName()); | ||
|
||
// If a name cannot be determined from the type, we fallback to the attribute name: | ||
// Prefix the attribute name with the parent element name resulting in a more unique type-name. | ||
if (!$attributeTypeName && !$attributeRestrictionName) { | ||
$typeName = (new AttributeDeclaringParentTypeDetector())($attribute, $parentContext->currentParent()) | ||
->andThen(static fn (Type $parent): Option => from_nullable($parent->getName())) | ||
->map(static fn (string $parentName): string => $parentName . ucfirst($typeName)) | ||
->unwrapOr($typeName); | ||
} | ||
|
||
return $typeName; | ||
} | ||
} |
31 changes: 31 additions & 0 deletions
31
src/Metadata/Converter/Types/Detector/ElementTypeNameDetector.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
<?php declare(strict_types=1); | ||
|
||
namespace Soap\WsdlReader\Metadata\Converter\Types\Detector; | ||
|
||
use GoetasWebservices\XML\XSDReader\Schema\Element\ElementItem; | ||
use GoetasWebservices\XML\XSDReader\Schema\Element\ElementSingle; | ||
use GoetasWebservices\XML\XSDReader\Schema\Type\SimpleType; | ||
use GoetasWebservices\XML\XSDReader\Schema\Type\Type; | ||
use Soap\WsdlReader\Metadata\Converter\Types\ParentContext; | ||
|
||
final class ElementTypeNameDetector | ||
{ | ||
public function __invoke(ElementItem $element, ParentContext $parentContext, ?string $calculatedTypeName = null): string | ||
{ | ||
$type = $element instanceof ElementSingle ? $element->getType() : null; | ||
$typeName = $calculatedTypeName ?? ($type?->getName() ?: $element->getName()); | ||
|
||
// For inline simple types, we prefix the name of the element with the name of the parent type. | ||
if ($type instanceof SimpleType && !$type->getName()) { | ||
$parent = $parentContext->currentParent(); | ||
|
||
if ($parent instanceof Type || $parent instanceof ElementItem) { | ||
if ($parentName = $parent->getName()) { | ||
$typeName = $parentName . ucfirst($typeName); | ||
} | ||
} | ||
} | ||
|
||
return $typeName; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
<?php declare(strict_types=1); | ||
|
||
namespace Soap\WsdlReader\Metadata\Converter\Types; | ||
|
||
use GoetasWebservices\XML\XSDReader\Schema\SchemaItem; | ||
use function Psl\Iter\first; | ||
use function Psl\Iter\last; | ||
|
||
final class ParentContext | ||
{ | ||
/** | ||
* @param non-empty-list<SchemaItem> $items | ||
*/ | ||
private function __construct( | ||
public readonly array $items, | ||
) { | ||
} | ||
|
||
public static function create(SchemaItem $item): self | ||
{ | ||
return new self([$item]); | ||
} | ||
|
||
public function withNextParent(SchemaItem $item): self | ||
{ | ||
return new self([...$this->items, $item]); | ||
} | ||
|
||
public function rootParent(): SchemaItem | ||
{ | ||
return first($this->items); | ||
} | ||
|
||
public function currentParent(): SchemaItem | ||
{ | ||
return last($this->items); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
--TEST-- | ||
SOAP XML Schema 1001: Prepend parent type name before attribute type names for more unique type-names. | ||
--FILE-- | ||
<?php | ||
include __DIR__."/test_schema.inc"; | ||
$schema = <<<EOF | ||
<complexType name="VehicleCoreType"> | ||
<sequence> | ||
<element name="VehType" minOccurs="0" type="string" /> | ||
</sequence> | ||
<attribute name="DriveType" use="optional"> | ||
<simpleType> | ||
<restriction base="NMTOKEN"> | ||
<enumeration value="AWD" /> | ||
<enumeration value="4WD" /> | ||
<enumeration value="Unspecified" /> | ||
</restriction> | ||
</simpleType> | ||
</attribute> | ||
</complexType> | ||
EOF; | ||
test_schema($schema,'type="tns:VehicleCoreType"'); | ||
?> | ||
--EXPECT-- | ||
Methods: | ||
> test(VehicleCoreType $testParam): void | ||
|
||
Types: | ||
> http://test-uri/:VehicleCoreType { | ||
?string $VehType | ||
@?VehicleCoreTypeDriveType in (AWD|4WD|Unspecified) $DriveType | ||
} |
Oops, something went wrong.