|  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Request #60615 Please extend the classmap option
Submitted: 2011-12-28 11:54 UTC Modified: -
Avg. Score:4.3 ± 0.5
Reproduced:3 of 3 (100.0%)
Same Version:1 (33.3%)
Same OS:1 (33.3%)
From: juwe at clasennet dot de Assigned:
Status: Open Package: SOAP related
PHP Version: Irrelevant OS: all
Private report: No CVE-ID: None
Welcome back! If you're the original bug submitter, here's where you can edit the bug or add additional notes.
If this is not your bug, you can add a comment by following this link.
If this is your bug, but you forgot your password, you can retrieve your password here.
Bug Type:
From: juwe at clasennet dot de
New email:
PHP Version: OS:


 [2011-12-28 11:54 UTC] juwe at clasennet dot de
Dear Devs,

currently we can map SOAP requests and responses to userland classes, using the classmap entry from SoapClient::__construct()'s options argument.

Sometimes those userland classes will have dependencies to be injected, before the SoapClient can fill them with their payload. Since SoapClient only accepts class names and not objects to be cloned or at least callbacks to act as a factory, bootstrapping these data objects is impossible.

Could you please change the current behavior in that regard?

In the interest of backwards compatibility, I suggest simply following the callback approach. If a callback is used, instead of a classname, PHP should use that callback as a factory for new classes. 

Test script:
Example to explain the idea:

class MySoapClient extends SoapClient

  public function __construct($wsdl,$dbAdapter)

    $options = array();
    // hard coded class name
    $options['classmap']['RequestType']  = 'RequestType';

    // anonymous function as factory
    $options['classmap']['ResponseType1'] = function() use($dbAdapter){
                                              $object=new MyResponseMapping();
                                              return $object;
    // factory method of a given class
    $options['classmap']['ResponseType2'] = array($this,'factoryMethod');


  /** a factory method for a certain kind of data access objects 
   *  @param void
   *  @return Object
  public function factoryMethod()
    $object=new MyResponseMapping();
    return $object;

$wsdl         = 'URL 2 a WDSL';

class RequestType


    public $payload; 


$request         = new RequestType;

$request->payload    = 'payload';

$soapclient = new MySoapClient($wsdl,$dbAdapter);

$result     = $soapclient->doSomething($request);


Expected result:
The var_dump() should reflect that objects of the MyResponseMapping types were used and their dependencies should have been fulfilled using the factories from my example. 

Actual result:
PHP silently (why?) ignores my mappings and uses stdClass objects instead.


Add a Patch

Pull Requests

Add a Pull Request


AllCommentsChangesGit/SVN commitsRelated reports
 [2023-04-04 05:39 UTC] marcusnguyeny75258 at gmail dot com
Thanks for share this information!!!!
 [2023-04-06 04:12 UTC] jaksujsha32 at gmail dot com
That was so amazing. (
PHP Copyright © 2001-2024 The PHP Group
All rights reserved.
Last updated: Tue Apr 16 08:01:32 2024 UTC