Pular para o conteúdo principal

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