Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/analyzers.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ jobs:
strategy:
matrix:
operating-system: [ubuntu-latest]
php-versions: [ '8.3', '8.4', '8.5' ]
php-versions: [ '8.4', '8.5' ]
composer-options: [ '--ignore-platform-req=php+' ]
fail-fast: false
name: PHP ${{ matrix.php-versions }} @ ${{ matrix.operating-system }}
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/code-style.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ jobs:
strategy:
matrix:
operating-system: [ubuntu-latest]
php-versions: [ '8.3', '8.4', '8.5' ]
php-versions: [ '8.4', '8.5' ]
composer-options: [ '--ignore-platform-req=php+' ]
fail-fast: false
name: PHP ${{ matrix.php-versions }} @ ${{ matrix.operating-system }}
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ jobs:
strategy:
matrix:
operating-system: [ubuntu-latest]
php-versions: [ '8.3', '8.4', '8.5' ]
php-versions: [ '8.4', '8.5' ]
composer-options: [ '--ignore-platform-req=php+' ]
fail-fast: false
name: PHP ${{ matrix.php-versions }} @ ${{ matrix.operating-system }}
Expand Down
10 changes: 5 additions & 5 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,17 +20,17 @@
}
],
"require": {
"php": "~8.3.0 || ~8.4.0 || ~8.5.0",
"php": "~8.4.0 || ~8.5.0",
"ext-dom": "*",
"php-soap/engine": "^2.16",
"php-soap/wsdl": "^1.14",
"php-soap/xml": "^1.9",
"php-soap/engine": "^2.19",
"php-soap/wsdl": "^1.19",
"php-soap/xml": "^1.10",
"php-http/discovery": "^1.12",
"psr/http-client-implementation": "^1.0",
"psr/http-factory-implementation": "^1.0",
"psr/http-message-implementation": "^1.0",
"psr/http-message": "^1.0.1|^2.0",
"veewee/xml": "^3.0",
"veewee/xml": "^4.9",
"php-http/client-common": "^2.3"
},
"require-dev": {
Expand Down
5 changes: 4 additions & 1 deletion psalm.xml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
errorLevel="1"
resolveFromConfigFile="true"
strictBinaryOperands="true"
phpVersion="8.3"
phpVersion="8.4"
allowStringToStandInForClass="true"
rememberPropertyAssignmentsAfterCall="false"
skipChecksOnUnresolvableIncludes="false"
Expand All @@ -13,6 +13,9 @@
xmlns="https://getpsalm.org/schema/config"
xsi:schemaLocation="https://getpsalm.org/schema/config vendor/vimeo/psalm/config.xsd"
>
<stubs>
<file name="vendor/veewee/xml/stubs/DOM.phpstub" />
</stubs>
<projectFiles>
<directory name="src" />
<ignoreFiles>
Expand Down
4 changes: 2 additions & 2 deletions src/Middleware/RemoveEmptyNodesMiddleware.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

namespace Soap\Psr18Transport\Middleware;

use DOMNode;
use Dom\Node;
use Http\Client\Common\Plugin;
use Http\Promise\Promise;
use Psr\Http\Message\RequestInterface;
Expand All @@ -23,7 +23,7 @@ static function (Document $xml): void {
do {
$emptyNodes = $xpath->query('//soap:Envelope/*//*[not(node())]');
$emptyNodes->forEach(
static fn (DOMNode $element) => remove($element)
static fn (Node $element) => remove($element)
);
} while ($emptyNodes->count());
}
Expand Down
10 changes: 5 additions & 5 deletions src/Middleware/SoapHeaderMiddleware.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@

namespace Soap\Psr18Transport\Middleware;

use DOMElement;
use DOMNode;
use Dom\Element;
use Dom\Node;
use Http\Client\Common\Plugin;
use Http\Promise\Promise;
use Psr\Http\Message\RequestInterface;
Expand All @@ -16,13 +16,13 @@
final class SoapHeaderMiddleware implements Plugin
{
/**
* @var list<callable(DOMNode): DOMElement>
* @var list<callable(Node): Element>
*/
private array $configurators;

/**
* @no-named-arguments
* @param list<callable(DOMNode): DOMElement> $configurators
* @param list<callable(Node): Element> $configurators
*/
public function __construct(callable ... $configurators)
{
Expand All @@ -34,7 +34,7 @@ public function handleRequest(RequestInterface $request, callable $next, callabl
return $next((new XmlMessageManipulator)(
$request,
function (Document $document) {
/** @var list<DOMElement> $headers */
/** @var list<Element> $headers */
$headers = $document->build(new SoapHeaders(...$this->configurators));

return $document->manipulate(new PrependSoapHeaders(...$headers));
Expand Down
6 changes: 3 additions & 3 deletions src/Middleware/Wsdl/DisableExtensionsMiddleware.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

namespace Soap\Psr18Transport\Middleware\Wsdl;

use DOMElement;
use Dom\Element;
use Http\Client\Common\Plugin;
use Http\Promise\Promise;
use Psr\Http\Message\RequestInterface;
Expand Down Expand Up @@ -31,9 +31,9 @@ private function disableExtensions(Document $document): void
$namespace = $document->locate(root_namespace_uri());
$document->xpath(new WsdlPreset($document))
->query('//wsdl:binding//*[@wsdl:required]')
->expectAllOfType(DOMElement::class)
->expectAllOfType(Element::class)
->forEach(
static function (DOMElement $element) use ($namespace): void {
static function (Element $element) use ($namespace): void {
namespaced_attribute($namespace ?? '', 'wsdl:required', 'false')($element);
}
);
Expand Down
10 changes: 5 additions & 5 deletions src/Middleware/Wsdl/DisablePoliciesMiddleware.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

namespace Soap\Psr18Transport\Middleware\Wsdl;

use DOMElement;
use Dom\Element;
use Http\Client\Common\Plugin;
use Http\Promise\Promise;
use Psr\Http\Message\RequestInterface;
Expand Down Expand Up @@ -35,18 +35,18 @@ public function disablePolicies(Document $document): void

// remove all "UsingPolicy" tags
$xpath->query('//wsd:UsingPolicy')
->expectAllOfType(DOMElement::class)
->expectAllOfType(Element::class)
->forEach(
static function (DOMElement $element): void {
static function (Element $element): void {
remove($element);
}
);

// remove all "Policy" tags
$xpath->query('//wsd:Policy')
->expectAllOfType(DOMElement::class)
->expectAllOfType(Element::class)
->forEach(
static function (DOMElement $element): void {
static function (Element $element): void {
remove($element);
}
);
Expand Down
6 changes: 3 additions & 3 deletions src/Xml/Loader/Psr7StreamLoader.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

namespace Soap\Psr18Transport\Xml\Loader;

use DOMDocument;
use Dom\XMLDocument;
use Psr\Http\Message\StreamInterface;
use Soap\Psr18Transport\Exception\RequestException;
use VeeWee\Xml\Dom\Loader\Loader;
Expand All @@ -22,14 +22,14 @@ public function __construct(StreamInterface $stream)
/**
* @throws RequestException
*/
public function __invoke(DOMDocument $document): void
public function __invoke(): XMLDocument
{
$this->stream->rewind();
$contents = (string) $this->stream;
if (!$contents) {
throw RequestException::noMessage();
}

xml_string_loader($contents)($document);
return xml_string_loader($contents)();
}
}
4 changes: 2 additions & 2 deletions src/Xml/Mapper/Psr7StreamMapper.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

namespace Soap\Psr18Transport\Xml\Mapper;

use DOMDocument;
use Dom\XMLDocument;
use Http\Discovery\Psr17FactoryDiscovery;
use Psr\Http\Message\StreamInterface;
use VeeWee\Xml\Dom\Mapper\Mapper;
Expand All @@ -14,7 +14,7 @@
*/
final class Psr7StreamMapper implements Mapper
{
public function __invoke(DOMDocument $document): StreamInterface
public function __invoke(XMLDocument $document): StreamInterface
{
$factory = Psr17FactoryDiscovery::findStreamFactory();
$stream = $factory->createStream($document->saveXML());
Expand Down
3 changes: 1 addition & 2 deletions src/Xml/XmlMessageManipulator.php
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@
use Soap\Psr18Transport\Xml\Loader\Psr7StreamLoader;
use Soap\Psr18Transport\Xml\Mapper\Psr7StreamMapper;
use VeeWee\Xml\Dom\Document;
use function VeeWee\Xml\Dom\Configurator\loader;

final class XmlMessageManipulator
{
Expand All @@ -20,7 +19,7 @@ final class XmlMessageManipulator
*/
public function __invoke(MessageInterface $message, callable $manipulator): MessageInterface
{
$document = Document::configure(loader(new Psr7StreamLoader($message->getBody())));
$document = Document::fromLoader(new Psr7StreamLoader($message->getBody()));
$manipulator($document);

return $message->withBody($document->map(new Psr7StreamMapper()));
Expand Down
4 changes: 2 additions & 2 deletions tests/Unit/Xml/XmlMessageManipulatorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

namespace SoapTest\Psr18Transport\Xml;

use DOMDocument;
use Dom\XMLDocument;
use Http\Discovery\Psr17FactoryDiscovery;
use PHPUnit\Framework\TestCase;
use Psr\Http\Message\ResponseInterface;
Expand All @@ -19,7 +19,7 @@ public function test_it_can_manipulate_an_xml_stream(): void
$message = Psr17FactoryDiscovery::findResponseFactory()->createResponse()->withBody($stream);

$manipulated = (new XmlMessageManipulator)($message, static function (Document $doc): void {
$doc->manipulate(static function (DOMDocument $dom) {
$doc->manipulate(static function (XMLDocument $dom) {
$dom->documentElement->setAttribute('name', 'world');
});
});
Expand Down