Skip to main content

Soap Server

Build Status Opensource ByJG GitHub source GitHub license GitHub release

A lightweight and modern SOAP server implementation for PHP 8.1+

Features​

  • πŸš€ Modern PHP 8.1+ Attributes: Use PHP attributes to define SOAP services declaratively
  • πŸ“ Auto-generated WSDL: Automatic WSDL generation from your service definitions
  • 🎨 Beautiful Documentation UI: Modern, interactive HTML documentation with Jinja templates
  • πŸ”§ Flexible Configuration: Support for both attribute-based and programmatic configuration
  • πŸ“Š Type Safety: Full support for complex types, arrays, and optional parameters
  • 🌐 SOAP 1.1 & 1.2: Support for both SOAP versions
  • 🎯 Discovery Support: Built-in DISCO (Discovery) document generation
  • πŸ“± Responsive Design: Mobile-friendly service documentation interface

Installation​

composer require byjg/soap-server

Quick Start​

<?php

use ByJG\SoapServer\Attributes\{SoapService, SoapOperation, SoapParameter};
use ByJG\SoapServer\SoapAttributeParser;
use ByJG\SoapServer\ResponseWriter;

#[SoapService(
serviceName: 'CalculatorService',
namespace: 'http://example.com/calculator',
description: 'A simple calculator web service'
)]
class Calculator
{
#[SoapOperation(description: 'Adds two numbers together')]
public function add(
#[SoapParameter(description: 'First number')] int $a,
#[SoapParameter(description: 'Second number')] int $b
): int {
return $a + $b;
}

#[SoapOperation(description: 'Subtracts second from first')]
public function subtract(int $a, int $b): int
{
return $a - $b;
}
}

// Start the service
$handler = SoapAttributeParser::parse(Calculator::class);
$response = $handler->handle();
ResponseWriter::output($response);

Using Programmatic Configuration​

<?php

use ByJG\SoapServer\{SoapHandler, SoapOperationConfig, SoapParameterConfig, SoapType};
use ByJG\SoapServer\ResponseWriter;

$addOperation = new SoapOperationConfig();
$addOperation->description = 'Adds two numbers';
$addOperation->args = [
new SoapParameterConfig('a', SoapType::Integer),
new SoapParameterConfig('b', SoapType::Integer)
];
$addOperation->returnType = SoapType::Integer;
$addOperation->executor = function(array $params) {
return $params['a'] + $params['b'];
};

$handler = new SoapHandler(
soapItems: ['add' => $addOperation],
serviceName: 'CalculatorService'
);
$response = $handler->handle();
ResponseWriter::output($response);

Running the Service​

Start PHP's built-in web server:

php -S localhost:8080 calculator.php

Then access:

Running Tests​

composer install
composer test

Running Static Analysis​

composer psalm

Documentation​

Comprehensive documentation is available:

License and Acknowledgments​

This project is licensed under the MIT License.

Note: Parts of this codebase were derived from an older PHP class originally licensed under the PHP License. The original code has been modernized and adapted for this project. For detailed information about the licensing and acknowledgments, see License Acknowledgments.

Dependencies​


Open source ByJG