wp/wp-includes/class-IXR.php
author ymh <ymh.work@gmail.com>
Tue, 09 Jun 2015 03:35:32 +0200
changeset 5 5e2f62d02dcd
parent 0 d970ebf37754
child 7 cf61fcea0001
permissions -rw-r--r--
upgrade wordpress + plugins
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * IXR - The Incutio XML-RPC Library
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * Copyright (c) 2010, Incutio Ltd.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 * All rights reserved.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 * Redistribution and use in source and binary forms, with or without
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
 * modification, are permitted provided that the following conditions are met:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
 *  - Redistributions of source code must retain the above copyright notice,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
 *    this list of conditions and the following disclaimer.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
 *  - Redistributions in binary form must reproduce the above copyright
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
 *    notice, this list of conditions and the following disclaimer in the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
 *    documentation and/or other materials provided with the distribution.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 *  - Neither the name of Incutio Ltd. nor the names of its contributors
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
 *    may be used to endorse or promote products derived from this software
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
 *    without specific prior written permission.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
 * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    33
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
 * @copyright  Incutio Ltd 2010 (http://www.incutio.com)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
 * @version    1.7.4 7th September 2010
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
 * @author     Simon Willison
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
 * @link       http://scripts.incutio.com/xmlrpc/ Site/manual
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
 * @license    http://www.opensource.org/licenses/bsd-license.php BSD
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
 * IXR_Value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    46
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
class IXR_Value {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
    var $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
    var $type;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
    function IXR_Value($data, $type = false)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
        $this->data = $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
        if (!$type) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
            $type = $this->calculateType();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
        $this->type = $type;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
        if ($type == 'struct') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
            // Turn all the values in the array in to new IXR_Value objects
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
            foreach ($this->data as $key => $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
                $this->data[$key] = new IXR_Value($value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
        if ($type == 'array') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
            for ($i = 0, $j = count($this->data); $i < $j; $i++) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
                $this->data[$i] = new IXR_Value($this->data[$i]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
    function calculateType()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
        if ($this->data === true || $this->data === false) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
            return 'boolean';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
        if (is_integer($this->data)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
            return 'int';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
        if (is_double($this->data)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
            return 'double';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
        // Deal with IXR object types base64 and date
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
        if (is_object($this->data) && is_a($this->data, 'IXR_Date')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
            return 'date';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
        if (is_object($this->data) && is_a($this->data, 'IXR_Base64')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
            return 'base64';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
        // If it is a normal PHP object convert it in to a struct
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
        if (is_object($this->data)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
            $this->data = get_object_vars($this->data);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
            return 'struct';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
        if (!is_array($this->data)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
            return 'string';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
        // We have an array - is it an array or a struct?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
        if ($this->isStruct($this->data)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
            return 'struct';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
            return 'array';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
    function getXml()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
        // Return XML for this value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
        switch ($this->type) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
            case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
                return '<boolean>'.(($this->data) ? '1' : '0').'</boolean>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
            case 'int':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
                return '<int>'.$this->data.'</int>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
            case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
                return '<double>'.$this->data.'</double>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
            case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
                return '<string>'.htmlspecialchars($this->data).'</string>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
            case 'array':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
                $return = '<array><data>'."\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
                foreach ($this->data as $item) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
                    $return .= '  <value>'.$item->getXml()."</value>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
                $return .= '</data></array>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
                return $return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
            case 'struct':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
                $return = '<struct>'."\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
                foreach ($this->data as $name => $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
					$name = htmlspecialchars($name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
                    $return .= "  <member><name>$name</name><value>";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
                    $return .= $value->getXml()."</value></member>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
                $return .= '</struct>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
                return $return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
            case 'date':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
            case 'base64':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
                return $this->data->getXml();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
        return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
     * Checks whether or not the supplied array is a struct or not
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
     *
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   154
     * @param array $array
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
     * @return boolean
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
    function isStruct($array)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
        $expected = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
        foreach ($array as $key => $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
            if ((string)$key != (string)$expected) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
                return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
            $expected++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
        return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
 * IXR_MESSAGE
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   174
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
class IXR_Message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
    var $message;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
    var $messageType;  // methodCall / methodResponse / fault
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
    var $faultCode;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
    var $faultString;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
    var $methodName;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
    var $params;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
    // Current variable stacks
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
    var $_arraystructs = array();   // The stack used to keep track of the current array/struct
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
    var $_arraystructstypes = array(); // Stack keeping track of if things are structs or array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
    var $_currentStructName = array();  // A stack as well
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
    var $_param;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
    var $_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
    var $_currentTag;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
    var $_currentTagContents;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
    // The XML parser
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
    var $_parser;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
    function IXR_Message($message)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
        $this->message =& $message;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
    function parse()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
        // first remove the XML declaration
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
        // merged from WP #10698 - this method avoids the RAM usage of preg_replace on very large messages
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   206
        $header = preg_replace( '/<\?xml.*?\?'.'>/s', '', substr( $this->message, 0, 100 ), 1 );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   207
        $this->message = trim( substr_replace( $this->message, $header, 0, 100 ) );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   208
        if ( '' == $this->message ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   209
            return false;
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   210
        }
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   211
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   212
        // Then remove the DOCTYPE
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   213
        $header = preg_replace( '/^<!DOCTYPE[^>]*+>/i', '', substr( $this->message, 0, 200 ), 1 );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   214
        $this->message = trim( substr_replace( $this->message, $header, 0, 200 ) );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   215
        if ( '' == $this->message ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   216
            return false;
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   217
        }
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   218
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   219
        // Check that the root tag is valid
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   220
        $root_tag = substr( $this->message, 0, strcspn( substr( $this->message, 0, 20 ), "> \t\r\n" ) );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   221
        if ( '<!DOCTYPE' === strtoupper( $root_tag ) ) {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
        }
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   224
        if ( ! in_array( $root_tag, array( '<methodCall', '<methodResponse', '<fault' ) ) ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   225
            return false;
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   226
        }
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   227
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   228
        // Bail if there are too many elements to parse
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   229
        $element_limit = 30000;
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   230
        if ( function_exists( 'apply_filters' ) ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   231
            /**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   232
             * Filter the number of elements to parse in an XML-RPC response.
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   233
             *
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   234
             * @since 4.0.0
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   235
             *
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   236
             * @param int $element_limit Default elements limit.
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   237
             */
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   238
            $element_limit = apply_filters( 'xmlrpc_element_limit', $element_limit );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   239
        }
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   240
        if ( $element_limit && 2 * $element_limit < substr_count( $this->message, '<' ) ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   241
            return false;
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   242
        }
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   243
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
        $this->_parser = xml_parser_create();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
        // Set XML parser to take the case of tags in to account
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
        xml_parser_set_option($this->_parser, XML_OPTION_CASE_FOLDING, false);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
        // Set XML parser callback functions
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
        xml_set_object($this->_parser, $this);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
        xml_set_element_handler($this->_parser, 'tag_open', 'tag_close');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
        xml_set_character_data_handler($this->_parser, 'cdata');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
        $chunk_size = 262144; // 256Kb, parse in chunks to avoid the RAM usage on very large messages
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
        $final = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
        do {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
            if (strlen($this->message) <= $chunk_size) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
                $final = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
            $part = substr($this->message, 0, $chunk_size);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
            $this->message = substr($this->message, $chunk_size);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
            if (!xml_parse($this->_parser, $part, $final)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
            if ($final) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
        } while (true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
        xml_parser_free($this->_parser);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
        // Grab the error messages, if any
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
        if ($this->messageType == 'fault') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
            $this->faultCode = $this->params[0]['faultCode'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
            $this->faultString = $this->params[0]['faultString'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
    function tag_open($parser, $tag, $attr)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
        $this->_currentTagContents = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
        $this->currentTag = $tag;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
        switch($tag) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
            case 'methodCall':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
            case 'methodResponse':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
            case 'fault':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
                $this->messageType = $tag;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
                /* Deal with stacks of arrays and structs */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
            case 'data':    // data is to all intents and puposes more interesting than array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
                $this->_arraystructstypes[] = 'array';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
                $this->_arraystructs[] = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
            case 'struct':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
                $this->_arraystructstypes[] = 'struct';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
                $this->_arraystructs[] = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
    function cdata($parser, $cdata)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
        $this->_currentTagContents .= $cdata;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
    function tag_close($parser, $tag)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
        $valueFlag = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
        switch($tag) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
            case 'int':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
            case 'i4':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
                $value = (int)trim($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
            case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
                $value = (double)trim($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
            case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
                $value = (string)trim($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
            case 'dateTime.iso8601':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
                $value = new IXR_Date(trim($this->_currentTagContents));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
            case 'value':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
                // "If no type is indicated, the type is string."
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
                if (trim($this->_currentTagContents) != '') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
                    $value = (string)$this->_currentTagContents;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
                    $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
            case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
                $value = (boolean)trim($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
            case 'base64':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
                $value = base64_decode($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
                /* Deal with stacks of arrays and structs */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
            case 'data':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
            case 'struct':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
                $value = array_pop($this->_arraystructs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
                array_pop($this->_arraystructstypes);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
                $valueFlag = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
            case 'member':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
                array_pop($this->_currentStructName);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
            case 'name':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
                $this->_currentStructName[] = trim($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
            case 'methodName':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
                $this->methodName = trim($this->_currentTagContents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
        if ($valueFlag) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
            if (count($this->_arraystructs) > 0) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
                // Add value to struct or array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
                if ($this->_arraystructstypes[count($this->_arraystructstypes)-1] == 'struct') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
                    // Add to struct
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
                    $this->_arraystructs[count($this->_arraystructs)-1][$this->_currentStructName[count($this->_currentStructName)-1]] = $value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
                } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
                    // Add to array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
                    $this->_arraystructs[count($this->_arraystructs)-1][] = $value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
            } else {
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   368
                // Just add as a parameter
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
                $this->params[] = $value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
        $this->_currentTagContents = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
 * IXR_Server
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   380
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
class IXR_Server
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
    var $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
    var $callbacks = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
    var $message;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
    var $capabilities;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
    function IXR_Server($callbacks = false, $data = false, $wait = false)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
        $this->setCapabilities();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
        if ($callbacks) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
            $this->callbacks = $callbacks;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
        $this->setCallbacks();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
        if (!$wait) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
            $this->serve($data);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
    function serve($data = false)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
        if (!$data) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
            if (isset($_SERVER['REQUEST_METHOD']) && $_SERVER['REQUEST_METHOD'] !== 'POST') {
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   405
                if ( function_exists( 'status_header' ) ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   406
                    status_header( 405 ); // WP #20986
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   407
                    header( 'Allow: POST' );
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   408
                }
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   409
                header('Content-Type: text/plain'); // merged from WP #9093
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
                die('XML-RPC server accepts POST requests only.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
            global $HTTP_RAW_POST_DATA;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
            if (empty($HTTP_RAW_POST_DATA)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
                // workaround for a bug in PHP 5.2.2 - http://bugs.php.net/bug.php?id=41293
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
                $data = file_get_contents('php://input');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
            } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
                $data =& $HTTP_RAW_POST_DATA;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
        $this->message = new IXR_Message($data);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
        if (!$this->message->parse()) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
            $this->error(-32700, 'parse error. not well formed');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
        if ($this->message->messageType != 'methodCall') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
            $this->error(-32600, 'server error. invalid xml-rpc. not conforming to spec. Request must be a methodCall');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
        $result = $this->call($this->message->methodName, $this->message->params);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
        // Is the result an error?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
        if (is_a($result, 'IXR_Error')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
            $this->error($result);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
        // Encode the result
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
        $r = new IXR_Value($result);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
        $resultxml = $r->getXml();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
        // Create the XML
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
        $xml = <<<EOD
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
<methodResponse>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
  <params>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
    <param>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
      <value>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
      $resultxml
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
      </value>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
    </param>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
  </params>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
</methodResponse>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
EOD;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
      // Send it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
      $this->output($xml);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
    function call($methodname, $args)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
        if (!$this->hasMethod($methodname)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
            return new IXR_Error(-32601, 'server error. requested method '.$methodname.' does not exist.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
        $method = $this->callbacks[$methodname];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
        // Perform the callback and send the response
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
        if (count($args) == 1) {
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   465
            // If only one parameter just send that instead of the whole array
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
            $args = $args[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
        // Are we dealing with a function or a method?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
        if (is_string($method) && substr($method, 0, 5) == 'this:') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
            // It's a class method - check it exists
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
            $method = substr($method, 5);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
            if (!method_exists($this, $method)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
                return new IXR_Error(-32601, 'server error. requested class method "'.$method.'" does not exist.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
            //Call the method
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
            $result = $this->$method($args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
            // It's a function - does it exist?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
            if (is_array($method)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
                if (!is_callable(array($method[0], $method[1]))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
                    return new IXR_Error(-32601, 'server error. requested object method "'.$method[1].'" does not exist.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
            } else if (!function_exists($method)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
                return new IXR_Error(-32601, 'server error. requested function "'.$method.'" does not exist.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
            // Call the function
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
            $result = call_user_func($method, $args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
        return $result;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
    function error($error, $message = false)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
        // Accepts either an error object or an error code and message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
        if ($message && !is_object($error)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
            $error = new IXR_Error($error, $message);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
        $this->output($error->getXml());
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
    function output($xml)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
        $charset = function_exists('get_option') ? get_option('blog_charset') : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
        if ($charset)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
            $xml = '<?xml version="1.0" encoding="'.$charset.'"?>'."\n".$xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
        else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
            $xml = '<?xml version="1.0"?>'."\n".$xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
        $length = strlen($xml);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
        header('Connection: close');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
        header('Content-Length: '.$length);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
        if ($charset)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
            header('Content-Type: text/xml; charset='.$charset);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
        else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
            header('Content-Type: text/xml');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
        header('Date: '.date('r'));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
        echo $xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
        exit;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
    function hasMethod($method)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
        return in_array($method, array_keys($this->callbacks));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
    function setCapabilities()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
        // Initialises capabilities array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
        $this->capabilities = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
            'xmlrpc' => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
                'specUrl' => 'http://www.xmlrpc.com/spec',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
                'specVersion' => 1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
        ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
            'faults_interop' => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
                'specUrl' => 'http://xmlrpc-epi.sourceforge.net/specs/rfc.fault_codes.php',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
                'specVersion' => 20010516
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
        ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
            'system.multicall' => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
                'specUrl' => 'http://www.xmlrpc.com/discuss/msgReader$1208',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
                'specVersion' => 1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
        ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
    function getCapabilities($args)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
        return $this->capabilities;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
    function setCallbacks()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
        $this->callbacks['system.getCapabilities'] = 'this:getCapabilities';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
        $this->callbacks['system.listMethods'] = 'this:listMethods';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
        $this->callbacks['system.multicall'] = 'this:multiCall';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
    function listMethods($args)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
        // Returns a list of methods - uses array_reverse to ensure user defined
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
        // methods are listed before server defined methods
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
        return array_reverse(array_keys($this->callbacks));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
    function multiCall($methodcalls)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
        // See http://www.xmlrpc.com/discuss/msgReader$1208
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
        $return = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
        foreach ($methodcalls as $call) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
            $method = $call['methodName'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
            $params = $call['params'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
            if ($method == 'system.multicall') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
                $result = new IXR_Error(-32600, 'Recursive calls to system.multicall are forbidden');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
            } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
                $result = $this->call($method, $params);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
            if (is_a($result, 'IXR_Error')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
                $return[] = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
                    'faultCode' => $result->code,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
                    'faultString' => $result->message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
                );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
            } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
                $return[] = array($result);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
        return $return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
 * IXR_Request
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   595
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
class IXR_Request
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
    var $method;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
    var $args;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
    var $xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
    function IXR_Request($method, $args)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
        $this->method = $method;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
        $this->args = $args;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
        $this->xml = <<<EOD
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
<?xml version="1.0"?>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
<methodCall>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
<methodName>{$this->method}</methodName>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
<params>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
EOD;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
        foreach ($this->args as $arg) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
            $this->xml .= '<param><value>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
            $v = new IXR_Value($arg);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
            $this->xml .= $v->getXml();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
            $this->xml .= "</value></param>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
        $this->xml .= '</params></methodCall>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
    function getLength()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
        return strlen($this->xml);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
    function getXml()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
        return $this->xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
 * IXR_Client
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   638
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
class IXR_Client
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
    var $server;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
    var $port;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
    var $path;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
    var $useragent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
    var $response;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
    var $message = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
    var $debug = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
    var $timeout;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
    var $headers = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
    // Storage place for an error message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
    var $error = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
    function IXR_Client($server, $path = false, $port = 80, $timeout = 15)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
        if (!$path) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
            // Assume we have been given a URL instead
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
            $bits = parse_url($server);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
            $this->server = $bits['host'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
            $this->port = isset($bits['port']) ? $bits['port'] : 80;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
            $this->path = isset($bits['path']) ? $bits['path'] : '/';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
            // Make absolutely sure we have a path
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
            if (!$this->path) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
                $this->path = '/';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
            }
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   669
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   670
            if ( ! empty( $bits['query'] ) ) {
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   671
                $this->path .= '?' . $bits['query'];
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   672
            }
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
            $this->server = $server;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
            $this->path = $path;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
            $this->port = $port;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
        $this->useragent = 'The Incutio XML-RPC PHP Library';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
        $this->timeout = $timeout;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
    function query()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
        $args = func_get_args();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
        $method = array_shift($args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
        $request = new IXR_Request($method, $args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
        $length = $request->getLength();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
        $xml = $request->getXml();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
        $r = "\r\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
        $request  = "POST {$this->path} HTTP/1.0$r";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
        // Merged from WP #8145 - allow custom headers
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
        $this->headers['Host']          = $this->server;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
        $this->headers['Content-Type']  = 'text/xml';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
        $this->headers['User-Agent']    = $this->useragent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
        $this->headers['Content-Length']= $length;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
        foreach( $this->headers as $header => $value ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
            $request .= "{$header}: {$value}{$r}";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
        $request .= $r;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
        $request .= $xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
        // Now send the request
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
        if ($this->debug) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
            echo '<pre class="ixr_request">'.htmlspecialchars($request)."\n</pre>\n\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
        if ($this->timeout) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
            $fp = @fsockopen($this->server, $this->port, $errno, $errstr, $this->timeout);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
            $fp = @fsockopen($this->server, $this->port, $errno, $errstr);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
        if (!$fp) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
            $this->error = new IXR_Error(-32300, 'transport error - could not open socket');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
        fputs($fp, $request);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
        $contents = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
        $debugContents = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
        $gotFirstLine = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
        $gettingHeaders = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
        while (!feof($fp)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
            $line = fgets($fp, 4096);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
            if (!$gotFirstLine) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
                // Check line for '200'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
                if (strstr($line, '200') === false) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
                    $this->error = new IXR_Error(-32300, 'transport error - HTTP status code was not 200');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
                    return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
                $gotFirstLine = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
            if (trim($line) == '') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
                $gettingHeaders = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
            if (!$gettingHeaders) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
            	// merged from WP #12559 - remove trim
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
                $contents .= $line;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
            if ($this->debug) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
            	$debugContents .= $line;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
        if ($this->debug) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
            echo '<pre class="ixr_response">'.htmlspecialchars($debugContents)."\n</pre>\n\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
        // Now parse what we've got back
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
        $this->message = new IXR_Message($contents);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
        if (!$this->message->parse()) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
            // XML error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
            $this->error = new IXR_Error(-32700, 'parse error. not well formed');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
        // Is the message a fault?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
        if ($this->message->messageType == 'fault') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
            $this->error = new IXR_Error($this->message->faultCode, $this->message->faultString);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
        // Message must be OK
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
    function getResponse()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
        // methodResponses can only have one param - return that
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
        return $this->message->params[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
    function isError()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
        return (is_object($this->error));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
    function getErrorCode()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
        return $this->error->code;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
    function getErrorMessage()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
        return $this->error->message;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
 * IXR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   794
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
class IXR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
    var $code;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
    var $message;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
    function IXR_Error($code, $message)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
        $this->code = $code;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
        $this->message = htmlspecialchars($message);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
    function getXml()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
        $xml = <<<EOD
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
<methodResponse>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
  <fault>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
    <value>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
      <struct>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
        <member>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
          <name>faultCode</name>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
          <value><int>{$this->code}</int></value>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
        </member>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
        <member>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
          <name>faultString</name>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
          <value><string>{$this->message}</string></value>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
        </member>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
      </struct>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
    </value>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
  </fault>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
</methodResponse>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
EOD;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
        return $xml;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
 * IXR_Date
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   836
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
class IXR_Date {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
    var $year;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
    var $month;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
    var $day;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
    var $hour;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
    var $minute;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
    var $second;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
    var $timezone;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
    function IXR_Date($time)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
        // $time can be a PHP timestamp or an ISO one
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
        if (is_numeric($time)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
            $this->parseTimestamp($time);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
            $this->parseIso($time);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
    function parseTimestamp($timestamp)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
        $this->year = date('Y', $timestamp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
        $this->month = date('m', $timestamp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
        $this->day = date('d', $timestamp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
        $this->hour = date('H', $timestamp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
        $this->minute = date('i', $timestamp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
        $this->second = date('s', $timestamp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
        $this->timezone = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
    function parseIso($iso)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
        $this->year = substr($iso, 0, 4);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
        $this->month = substr($iso, 4, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
        $this->day = substr($iso, 6, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
        $this->hour = substr($iso, 9, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
        $this->minute = substr($iso, 12, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
        $this->second = substr($iso, 15, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
        $this->timezone = substr($iso, 17);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
    function getIso()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
        return $this->year.$this->month.$this->day.'T'.$this->hour.':'.$this->minute.':'.$this->second.$this->timezone;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
    function getXml()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
        return '<dateTime.iso8601>'.$this->getIso().'</dateTime.iso8601>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
    function getTimestamp()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
        return mktime($this->hour, $this->minute, $this->second, $this->month, $this->day, $this->year);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
 * IXR_Base64
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   899
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
class IXR_Base64
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
    var $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
    function IXR_Base64($data)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
        $this->data = $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
    function getXml()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
        return '<base64>'.base64_encode($this->data).'</base64>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
 * IXR_IntrospectionServer
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   920
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
class IXR_IntrospectionServer extends IXR_Server
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
    var $signatures;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
    var $help;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
    function IXR_IntrospectionServer()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
        $this->setCallbacks();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
        $this->setCapabilities();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
        $this->capabilities['introspection'] = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
            'specUrl' => 'http://xmlrpc.usefulinc.com/doc/reserved.html',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
            'specVersion' => 1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
        $this->addCallback(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
            'system.methodSignature',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
            'this:methodSignature',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
            array('array', 'string'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
            'Returns an array describing the return type and required parameters of a method'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   940
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   941
        $this->addCallback(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   942
            'system.getCapabilities',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   943
            'this:getCapabilities',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
            array('struct'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
            'Returns a struct describing the XML-RPC specifications supported by this server'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
        $this->addCallback(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   948
            'system.listMethods',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
            'this:listMethods',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
            array('array'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
            'Returns an array of available methods on this server'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
        $this->addCallback(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
            'system.methodHelp',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
            'this:methodHelp',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
            array('string', 'string'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
            'Returns a documentation string for the specified method'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
    function addCallback($method, $callback, $args, $help)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   963
        $this->callbacks[$method] = $callback;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   964
        $this->signatures[$method] = $args;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
        $this->help[$method] = $help;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
    function call($methodname, $args)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
        // Make sure it's in an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
        if ($args && !is_array($args)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
            $args = array($args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
        // Over-rides default call method, adds signature check
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
        if (!$this->hasMethod($methodname)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
            return new IXR_Error(-32601, 'server error. requested method "'.$this->message->methodName.'" not specified.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
        $method = $this->callbacks[$methodname];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
        $signature = $this->signatures[$methodname];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
        $returnType = array_shift($signature);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
        // Check the number of arguments
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
        if (count($args) != count($signature)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
            return new IXR_Error(-32602, 'server error. wrong number of method parameters');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   988
        // Check the argument types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   989
        $ok = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
        $argsbackup = $args;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
        for ($i = 0, $j = count($args); $i < $j; $i++) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
            $arg = array_shift($args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   993
            $type = array_shift($signature);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
            switch ($type) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
                case 'int':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   996
                case 'i4':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   997
                    if (is_array($arg) || !is_int($arg)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
                        $ok = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
                case 'base64':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
                case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1003
                    if (!is_string($arg)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
                        $ok = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
                case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
                    if ($arg !== false && $arg !== true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
                        $ok = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
                case 'float':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
                case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
                    if (!is_float($arg)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
                        $ok = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
                case 'date':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
                case 'dateTime.iso8601':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1020
                    if (!is_a($arg, 'IXR_Date')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1021
                        $ok = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1022
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1023
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
            if (!$ok) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1026
                return new IXR_Error(-32602, 'server error. invalid method parameters');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
        // It passed the test - run the "real" method call
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
        return parent::call($methodname, $argsbackup);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
    function methodSignature($method)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
        if (!$this->hasMethod($method)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
            return new IXR_Error(-32601, 'server error. requested method "'.$method.'" not specified.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
        // We should be returning an array of types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1039
        $types = $this->signatures[$method];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1040
        $return = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
        foreach ($types as $type) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1042
            switch ($type) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
                case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
                    $return[] = 'string';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
                case 'int':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
                case 'i4':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
                    $return[] = 42;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
                case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
                    $return[] = 3.1415;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
                case 'dateTime.iso8601':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
                    $return[] = new IXR_Date(time());
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1055
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1056
                case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1057
                    $return[] = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1058
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
                case 'base64':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1060
                    $return[] = new IXR_Base64('base64');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1061
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1062
                case 'array':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1063
                    $return[] = array('array');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1064
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1065
                case 'struct':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1066
                    $return[] = array('struct' => 'struct');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1067
                    break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1068
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1069
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1070
        return $return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1071
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1072
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1073
    function methodHelp($method)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1074
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1075
        return $this->help[$method];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1076
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1077
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1078
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1079
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1080
 * IXR_ClientMulticall
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1081
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1082
 * @package IXR
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
  1083
 * @since 1.5.0
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1084
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1085
class IXR_ClientMulticall extends IXR_Client
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1086
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1087
    var $calls = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1088
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1089
    function IXR_ClientMulticall($server, $path = false, $port = 80)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1090
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1091
        parent::IXR_Client($server, $path, $port);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1092
        $this->useragent = 'The Incutio XML-RPC PHP Library (multicall client)';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1093
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1094
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1095
    function addCall()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1096
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1097
        $args = func_get_args();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1098
        $methodName = array_shift($args);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1099
        $struct = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1100
            'methodName' => $methodName,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1101
            'params' => $args
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1102
        );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1103
        $this->calls[] = $struct;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1104
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1105
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1106
    function query()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1107
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1108
        // Prepare multicall, then call the parent::query() method
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1109
        return parent::query('system.multicall', $this->calls);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1110
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1111
}