rogervila / laravel-soap-server
PHP Laravel SOAP Server
1.0.0
2025-03-14 13:48 UTC
Requires
- ext-soap: *
- laravel/framework: ^10 || ^11 || ^12
Requires (Dev)
- ext-dom: *
- orchestra/testbench: ^8 || ^9 || ^10
- phpstan/phpstan: ^2.0
- vimeo/psalm: ^6.0
README
Laravel SOAP Server
About
Laravel SOAP Server is a package that simplifies the creation of SOAP web services in Laravel. It provides a base setup for developing SOAP services, including WSDL generation and request handling.
Installation
To install the package, use Composer:
composer require rogervila/laravel-soap-server
Usage
Defining a Service
Create a service class that will handle the SOAP requests. For example, a UserService
class:
namespace App\Services; use stdClass; class UserService { public function createUser(stdClass $request): array { // Handle the request and return a response } }
Creating a WSDL View
Create a Blade view for the WSDL definition. For example, resources/views/wsdl.blade.php
:
<?xml version="1.0" encoding="UTF-8"?> <definitions name="UserService" targetNamespace="{{ url()->current() }}" xmlns:tns="{{ url()->current() }}" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns="http://schemas.xmlsoap.org/wsdl/"> <!-- Types definition --> <types> <xsd:schema targetNamespace="{{ url()->current() }}"> <!-- CreateUser Request Type --> <xsd:element name="CreateUserRequest"> <xsd:complexType> <xsd:sequence> <xsd:element name="name" type="xsd:string" minOccurs="1" maxOccurs="1"/> <xsd:element name="email" type="xsd:string" minOccurs="1" maxOccurs="1"/> </xsd:sequence> </xsd:complexType> </xsd:element> <!-- CreateUser Response Type --> <xsd:element name="CreateUserResponse"> <xsd:complexType> <xsd:sequence> <xsd:element name="status" type="xsd:string" minOccurs="1" maxOccurs="1"/> <xsd:element name="message" type="xsd:string" minOccurs="1" maxOccurs="1"/> <xsd:element name="data" minOccurs="0" maxOccurs="1"> <xsd:complexType> <xsd:sequence> <xsd:element name="id" type="xsd:integer"/> <xsd:element name="name" type="xsd:string"/> <xsd:element name="email" type="xsd:string"/> <xsd:element name="created_at" type="xsd:dateTime"/> </xsd:sequence> </xsd:complexType> </xsd:element> </xsd:sequence> </xsd:complexType> </xsd:element> </xsd:schema> </types> <!-- Message definitions --> <message name="CreateUserInput"> <part name="parameters" element="tns:CreateUserRequest"/> </message> <message name="CreateUserOutput"> <part name="parameters" element="tns:CreateUserResponse"/> </message> <!-- Port Type definitions --> <portType name="UserServicePortType"> <operation name="CreateUser"> <input message="tns:CreateUserInput"/> <output message="tns:CreateUserOutput"/> </operation> </portType> <!-- Binding definitions --> <binding name="UserServiceBinding" type="tns:UserServicePortType"> <soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/> <operation name="CreateUser"> <soap:operation soapAction="{{ url()->current() }}/CreateUser"/> <input> <soap:body use="literal"/> </input> <output> <soap:body use="literal"/> </output> </operation> </binding> <!-- Service definition --> <service name="UserService"> <port name="UserServicePort" binding="tns:UserServiceBinding"> <soap:address location="{{ url()->current() }}"/> </port> </service> </definitions>
Defining Routes
Define a route to handle the SOAP requests. For example, in routes/web.php
:
use App\Services\UserService; use LaravelSoapServer\Soap; /** * GET http://localhost:8000/user-soap-service?wsdl Returns the WSDL definition * POST http://localhost:8000/user-soap-service Handles the SOAP requests */ Route::any('/user-soap-service', function () { // Option 1 return Soap::handle(view: 'wsdl', service: UserService::class); // Option 2 return Soap::withView('wsdl') ->withService(UserService::class) ->withRequest(request()) // Optional: defaults to current request ->withOptions([]) // Optional: defaults to [] ->handle(); });
Testing the Service
You can test the service using a SOAP client or by writing tests. For example, a test case:
namespace Tests\Feature; use Tests\TestCase; class SoapTest extends TestCase { public function test_create_user() { $name = 'John Doe'; $email = 'john.doe@example.com'; $url = url('/user-soap-service'); $payload = <<<XML <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:soap="$url"> <soapenv:Header/> <soapenv:Body> <soap:CreateUserRequest> <name>$name</name> <email>$email</email> </soap:CreateUserRequest> </soapenv:Body> </soapenv:Envelope> XML; $response = $this->call('POST', $url, [], [], [], [ 'HTTP_SOAPACTION' => 'CreateUser', 'CONTENT_TYPE' => 'text/xml;charset=utf-8', 'CONTENT_LENGTH' => strlen($payload), ], $payload); $response->assertStatus(200); $response->assertHeader('Content-Type', 'application/soap+xml;charset=utf-8'); // ... } }
License
Laravel SOAP Server is open-sourced software licensed under the MIT license.
Icons made by justicon from www.flaticon.com