以前の開発者からアプリケーションを引き継ぎましたが、Nusoap を使用して半分完成したコードがいくつかありました。次のエラーが表示されます。
Call to register_donation() web service failed due to an exception: 
Function ("register_donation") is not a valid method for this service   
アプリケーションは以下に基づいて構築されています: CakePHP 1.2.10& using nuSoap 0.9.5.  
私はすでに持っていますini_set('soap.wsdl_cache_enabled', 0);(これは役に立ちません。)
私のコードは以下のとおりです (読みやすくするために短くしています)。この応答を正しく処理していますか? (コードは前の開発者から私が引き継いだものです)。
Pastebin (完全なコード) はこちら: PasteBin Link
以下に短縮版を示します。完全版は上のペーストビン リンクにあります。
<?php
ini_set('soap.wsdl_cache_enabled', 0);
class ServicesController extends AppController
{
var $uses = array("Donation");
var $components = array( "Email", "MatchingEvents" );
function registerDonation($donation = null){
    $this->log('hit registerDonation', 'donation');
    $this->autoRender = false;
    App::import('Vendor','nusoap');
    Configure::write('debug',0);
    Configure::write('Session.start', false);
    //init soap server
    $server = new soap_server();
    $endpoint = 'http://new.mysite.com/services/registerDonation';
    //initialize WSDL support
    $server->configureWSDL('donations', 'urn:donations', $endpoint);
    //setup service type
    $server->wsdl->addComplexType(
        'DonationResult',
        'complexType',
        'struct',
        'all',
        '',
        array(
            'success' => array('name' => 'success', 'type' => 'xsd:boolean'),
            'msg' => array('name' => 'msg', 'type' => 'xsd:string'),
            'error_number' => array('name' => 'error_number', 'type' => 'xsd:string')
        )
    );
    //register the method to expose
    $server->register('register_donation',
        array('ct_number' => 'xsd:string', 'project_id' => 'xsd:int', 'donation_amount' => 'xsd:decimal',
            // Stripped all other params
        ),
        array(
            'result' => 'tns:DonationResult'
        ),
        'urn:donations',
        'urn:donations#register_donation',
        'rpc',
        'encoded',
        'Accepts the results of a donation to a charity or project on the  site'
    );
    //This inner function is registered and then called (keep within outer function!)
    function register_donation(
        // Pass in all the params (Stripped for readability)
        $ct_number = null, $project_id = null, $donation_amount = null
    ){
        // This function is never hit!.. its not registered, why?
        $this->log('hit #3-register_donation called!', 'donation');
        $return = $this->Donation->add(array(
            'unique_id' => $unique_id,
            'ct_number' => $ct_number,
            'project_id' => $project_id,
            'donation_amount' => $donation_amount,
            // Pass in all other params, (Stripped for readability)
        ));
        // Process that request
        $log = $this->Donation->log . 'Result: ' . $return['msg'] . "\n";
        $this->log( $log, 'donation' );
        if ( isset($this->Donation->matching['events']) )
        {
            //Reserved donations should already have had their events handled
            $this->MatchingEvents->handle($this->Donation->matching, !$this->Donation->matching['reserved']);
        }
        if ( !empty($this->Donation->cacheSaved) )
            $this->_sendDonationEmails($this->Donation->cacheSaved);
        return $return;
    }
    $HTTP_RAW_POST_DATA = isset($GLOBALS['HTTP_RAW_POST_DATA']) ? $GLOBALS['HTTP_RAW_POST_DATA'] : '';
    $server->service($HTTP_RAW_POST_DATA);
}
function _sendDonationEmails($donation)
{
    // Send the emails
}
}
?>
提供できる情報が他にもありましたら、お知らせください。
要約:外部ソースからの nusoap 応答を処理するにはどうすればよいですか。
 デバッグのアイデア、ヒントとヒント、または解決策は報われます (+1!)。