Download the PHP package goetas-webservices/soap-client without Composer
On this page you can find all versions of the php package goetas-webservices/soap-client. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package soap-client
goetas-webservices / soap-client
PHP implementation of SOAP 1.1 and 1.2 client specifications.
Strengths:
- Pure PHP, no dependencies on
ext-soap
- Extensible (JMS event listeners support)
- PSR-7 HTTP messaging
- PSR-17 HTTP messaging factories
- PSR-18 HTTP Client
- No WSDL/XSD parsing on production
- IDE type hinting support
Only document/literal style is supported and the webservice should follow the WS-I guidelines.
There are no plans to support the deprecated rpc and encoded styles. Webservices not following the WS-I specifications might work, but they are officially not supported.
Demo
goetas-webservices/soap-client-demo is a demo project that shows how to consume a SOAP api in a generic PHP web application.
Installation
The recommended way to install goetas-webservices / soap-client is using Composer:
Add this packages to your composer.json
file.
How to
To improve performance, this library is based on the concept that all the SOAP/WSDL metadata has to be compiled into PHP compatible metadata (in reality is a big plain PHP array, so is really fast).
To do this we have to define a configuration file (in this case called config.yml
) that
holds some important information.
Here is an example:
This file has some important sections:
SOAP Specific
-
alternative_endpoints
(optional) allows you to specify alternative URLs that can be used when developing your integration. If this parameter is not present, will be used the URL defined by the WSDL file, but if is set, will be used the specified URL for the service called MyServiceName and on MySoapPortName port. unwrap_returns
(optional, default: false) allows to define the "wrapped" SOAP services mode. Instructs the client to "unwrap" all the returns.
WSDL Specific
metadata
specifies where are placed WSDL files that will be used to generate al the required PHP metadata.
XML/XSD Specific
-
namespaces
(required) defines the mapping between XML namespaces and PHP namespaces. (in the example we have thehttp://www.example.org/test/
XML namespace mapped toTestNs\MyApp
) -
destinations_php
(required) specifies the directory where to save the PHP classes that belongs toTestNs\MyApp
PHP namespace. (in this exampleTestNs\MyApp
classes will ne saved intosoap/src
directory. -
destinations_jms
(required) specifies the directory where to save JMS Serializer metadata files that belongs toTestNs\MyApp
PHP namespace. (in this exampleTestNs\MyApp
metadata will ne saved intosoap/metadata
directory. aliases
(optional) specifies some mappings that are handled by custom JMS serializer handlers. Allows to specify to do not generate metadata for some XML types, and assign them directly a PHP class. For that PHP class is necessary to create a custom JMS serialize/deserialize handler.
Metadata generation
In order to be able to use the SOAP client we have to generate some metadata and PHP classes.
To do it we can run:
bin/soap-client generate
is the command we are runningtests/config.yml
is a path to our configuration file--dest-class=GlobalWeather/Container/SoapClientContainer
allows to specify the fully qualified class name of the container class that will hold all the webservice metadata.soap/src/Container
is the path where to save the container class that holds all the webservice metadata (you will have to configure the auto loader to load it)
Using the client
Once all the metadata are generated we can use our SOAP client.
Let's see a minimal example:
Please note the @var $client \GlobalWeather\SoapStubs\WeatherSoap
. The generated metadata have also a "stub" class
that allows modern IDE to give you type hinting for parameters and return data.
This allows you to develop faster your client.
Using the client with dynamic endpoints
Suppose that you have same Webservice with different endpoints (ex. for each customer), so you want to change endpoints dynamically and you don't want to write each new endpoint in your config and run the generator for each customer.
With the help of Symfony's EnvVarProcessorInterface
,
you can use alternative_endpoints
to set dynamically the webservice endpoints.
Here is an example:
So, SoapClientContainer
will resolve at runtime the endpoint for the specific service and port and the value will be
taken from the ENDPOINT_SERVICE1_PORT1
variable.
Example of simple class that implements EnvVarProcessorInterface
, responsible for providing a values for
our custom endpoint locations (as custom_vars:ENDPOINT_SERVICE1_PORT1
).
At the end, to use the SoapClientContainer
:
In this way the endpoint for the MyServiceName
.MySoapPortName
will be dynamically resolved to http://localhost:8080/service
even if the WSDL stats something else.
Note
The code in this project is provided under the MIT license. For professional support contact [email protected] or visit https://www.goetas.com
All versions of soap-client with dependencies
psr/http-message Version ^1.0
psr/http-factory Version ^1.0
psr/http-client Version ^1.0
psr/http-factory-implementation Version ^1.0
psr/http-message-implementation Version ^1.0
psr/http-client-implementation Version ^1.0
php-http/discovery Version ^1.13
symfony/dependency-injection Version ^3.3|^4.0|^5.0
doctrine/instantiator Version ^1.0.3
jms/serializer Version ^1.6|^2.0|^3.0
goetas-webservices/xsd2php-runtime Version ^0.2.11
goetas-webservices/soap-common Version ^0.2.2
goetas-webservices/soap-reader Version ^0.3.3
goetas-webservices/xsd2php Version ^0.4.7
laminas/laminas-code Version ^4.8
laminas/laminas-zendframework-bridge Version ^1.7
doctrine/inflector Version ^2.0