Merge pull request #51 from FinesseRus/patch-1
[plcapi.git] / NEWS
1 XML-RPC for PHP version 4.1.0 - 2016/6/26
2
3 * improved: Added support for receiving <I8> and <EX:I8> integers, sending <I8>
4
5     If php is compiled in 32 bit mode, and an i8 int is received from a 3rd party, and error will be emitted.
6     Integers sent from the library to 3rd parties can be encoded using the i8 tag, but default to using 'int' by default;
7     the developer will have to create values as i8 explicitly if needed.
8     The library does *not* check if an outgoing integer is too big to fit in 4 bytes and convert it to an i8 automatically.
9
10 XML-RPC for PHP version 4.0.1 - 2016/3/27
11
12 * improved: all of the API documentation has been moved out of the manual and into the source code phpdoc comments
13
14 * fixed: when the internal character set is set to UTF-8 and the client sends requests (or the server responses), too
15   many characters were encoded as numeric entities, whereas some, like åäö, needed not not be
16
17 * fixed: the 'valtyp' property of Response was not present in all cases; the ValType property had been added by error
18   and has been removed
19
20
21 XML-RPC for PHP version 4.0.0 - 2016/1/20
22
23 This release does away with the past and starts a transition to modern-world php.
24
25 Code has been heavily refactored, taking care to preserve backwards compatibility as much as possible,
26 but some breackage is to be expected.
27
28 The minimum required php version has been increased to 5.3, even though we strongly urge you to use
29 more recent versions.
30
31 PLEASE READ CAREFULLY THE NOTES BELOW to insure a smooth upgrade.
32
33 * new: introduction of namespaces and full OOP.
34
35   All php classes have been renamed and moved to separate files.
36   Class autoloading can now be done in accord with the PSR-4 standard.
37   All global variables and global functions have been removed.
38   Iterating over xmlrpc value objects is now easier thank to support for ArrayAccess and Traversable interfaces.
39
40   Backward compatibility is maintained via lib/xmlrpc.inc, lib/xmlrpcs.inc and lib/xmlrpc_wrappers.inc.
41   For more details, head on to doc/api_changes_v4.md
42
43 * changed: the default character encoding delivered from the library to your code is now utf8.
44   It can be changed at any time setting a value to PhpXmlRpc\PhpXmlRpc::$xmlrpc_internalencoding
45
46 * improved: the library now accepts requests/responses sent using other character sets than UTF-8/ISO-8859-1/ASCII.
47   This only works when the mbstring php extension is enabled.
48
49 * improved: no need to call anymore $client->setSSLVerifyHost(2) to silence a curl warning when using https
50   with recent curl builds
51
52 * improved: the xmlrpcval class now supports the interfaces Countable and IteratorAggregate
53
54 * improved: a specific option allows users to decide the version of SSL to use for https calls.
55   This is useful f.e. for the testing suite, when the server target of calls has no proper ssl certificate,
56   and the cURL extension has been compiled with GnuTLS (such as on Travis VMs)
57
58 * improved: the function wrap_php_function() now can be used to wrap closures (it is now a method btw)
59
60 * improved: all wrap_something() functions now return a closure by default instead of a function name
61
62 * improved: debug messages are not html-escaped any more when executing from the command line
63
64 * improved: the library is now tested using Travis ( https://travis-ci.org/ ).
65   Tests are executed using all php versions from 5.3 to 7.0 nightly, plus HHVM; code-coverage information
66   is generated using php 5.6 and uploaded to both Code Coverage and Scrutinizer online services
67
68 * improved: phpunit is now installed via composer, not bundled anymore
69
70 * improved: when phpunit is used to generate code-coverage data, the code executed server-side is accounted for
71
72 * improved: the test suite has basic checks for the debugger and demo files
73
74 * improved: more tests in the test suite
75
76 * fixed: the server would not reset the user-set debug messages between subsequent service() calls
77
78 * fixed: the server would not reset previous php error handlers when an exception was thrown by user code and
79   exception_handling set to 2
80
81 * fixed: the server would fail to decode a request with ISO-8859-1 payload and character set declaration in the xml
82   prolog only
83
84 * fixed: the client would fail to decode a response with ISO-8859-1 payload and character set declaration in the xml
85   prolog only
86
87 * fixed: the function decode_xml() would not decode an xml with character set declaration in the xml prolog
88
89 * fixed: the client can now successfully call methods using ISO-8859-1 or UTF-8 characters in their name
90
91 * fixed: the debugger would fail sending a request with ISO-8859-1 payload (it missed the character set declaration).
92   It would have a hard time coping with ISO-8859-1 in other fields, such as e.g. the remote method name
93
94 * fixed: the debugger would generate a bad payload via the 'load method synopsis' button for signatures containing NULL
95   or undefined parameters
96
97 * fixed: the debugger would generate a bad payload via the 'load method synopsis' button for methods with multiple
98   signatures
99
100 * improved: the debugger is displayed using UTF-8, making it more useful to debug any kind of service
101
102 * improved: echo all debug messages even when there are characters in them which php deems to be in a wrong encoding;
103   previously those messages would just disappear (this is visible e.g. in the debugger)
104
105 * changed: debug info handling
106     - at debug level 1, the rebuilt php objects are not dumped to screen (server-side already did that)
107     - at debug level 1, curl communication info are not dumped to screen
108     - at debug level 1, the tests echo payloads of failures; at debug level 2 all payloads
109
110 * improved: makefiles have been replaced with a php_based pakefile
111
112 * improved: the source for the manual is stored in asciidoc format, which can be displayed natively by GitHub
113   with nice html formatting. Also the HTML version generated by hand and bundled in tarballs is much nicer
114   to look at than previous versions
115
116 * improved: all php code is now formatted according to the PSR-2 standard
117
118
119 XML-RPC for PHP version 3.0.0 - 2014/6/15
120
121 This release corrects all bugs that have been reported and successfully reproduced since
122 version 3.0.0 beta.
123
124 The requirements have increased to php 5.1.0 - which is still way older than what you should be running for any serious
125 purpose, really.
126
127 It also is the first release to be installable via composer.
128
129 See the Changelog file or the pdf docs for a complete list of changes.
130
131
132 XML-RPC for PHP version 3.0.0 beta - 2009/09/05
133
134 This is the first release of the library to only support PHP 5.
135 Some legacy code has been removed, and support for features such as exceptions
136 and dateTime objects introduced.
137
138 The "beta" tag is meant to indicate the fact that the refactoring has been more widespread
139 than in precedent releases and that more changes are likely to be introduced with time -
140 the library is still considered to be production quality.
141
142 * improved: removed all usage of php functions deprecated in php 5.3, usage of assign-by-ref when creating new objects
143   etc...
144 * improved: add support for the <ex:nil/> tag used by the apache library, both in input and output
145 * improved: add support for dateTime objects in both in php_xmlrpc_encode and as parameter for constructor of xmlrpcval
146 * improved: add support for timestamps as parameter for constructor of xmlrpcval
147 * improved: add option 'dates_as_objects' to php_xmlrpc_decode to return dateTime objects for xmlrpc datetimes
148 * improved: add new method SetCurlOptions to xmrlpc_client to allow extra flexibility in tweaking http config, such as
149   explicitly binding to an ip address
150 * improved: add new method SetUserAgent to xmrlpc_client to to allow having different user-agent http headers
151 * improved: add a new member variable in server class to allow fine-tuning of the encoding of returned values when the
152   server is in 'phpvals' mode
153 * improved: allow servers in 'xmlrpcvals' mode to also register plain php functions by defining them in the dispatch map
154   with an added option
155 * improved: catch exceptions thrown during execution of php functions exposed as methods by the server
156 * fixed: bad encoding if same object is encoded twice using php_xmlrpc_encode
157
158
159 XML-RPC for PHP version 2.2.2 - 2009/03/16
160
161 This release corrects all bugs that have been reported and sucesfully reproduced since
162 version 2.2.1.
163 Regardless of the intimidating message about dropping PHP 4 support, it still does
164 support that ancient, broken and insecure platform.
165
166
167 * fixed: php warning when receiving 'false' in a bool value
168 * fixed: improve robustness of the debugger when parsing weird results from non-compliant servers
169 * fixed: format floating point values using the correct decimal separator even when php locale is set to one that uses
170   comma
171 * fixed: use feof() to test if socket connections are to be closed instead of the number of bytes read (rare bug when
172   communicating with some servers)
173 * fixed: be more tolerant in detection of charset in http headers
174 * fixed: fix encoding of UTF8 chars outside of the BMP plane
175 * fixed: fix detection of zlib.output_compression
176 * improved: allow the add_to_map server method to add docs for single params too
177 * improved: added the possibility to wrap for exposure as xmlrpc methods plain php class methods, object methods and
178   even whole classes
179
180
181 XML-RPC for PHP version 2.2.1 - 2008/03/06
182
183 This release corrects all bugs that have been reported and sucesfully reproduced.
184 It is the last release of the library that will support PHP 4.
185
186 * fixed: work around bug in php 5.2.2 which broke support of HTTP_RAW_POST_DATA
187 * fixed: is_dir parameter of setCaCertificate() method is reversed
188 * fixed: a php warning in xmlrpc_client creator method
189 * fixed: parsing of '1e+1' as valid float
190 * fixed: allow errorlevel 3 to work when prev. error handler was a static method
191 * fixed: usage of client::setcookie() for multiple cookies in non-ssl mode
192 * improved: support for CP1252 charset is not part or the library but almost possible
193 * improved: more info when curl is enabled and debug mode is on
194
195
196 XML-RPC for PHP version 2.2 - 2007/02/25
197
198 This release corrects a couple of bugs and adds a few minor features.
199
200 * fixed: debugger errors on php installs with magic_quotes_gpc on
201 * fixed: support for https connections via proxy
202 * fixed: wrap_xmlrpc_method() generated code failed to properly encode php objects
203 * improved: slightly faster encoding of data which is internally UTF-8
204 * improved: debugger always generates a 'null' id for jsonrpc if user omits it
205 * new: debugger can take advantage of a graphical value builder
206   (it has to be downloaded separately, as part of jsxmlrpc package)
207 * new: support for the <NIL/> xmlrpc extension
208 * new: server support for the system.getCapabilities xmlrpc extension
209 * new: wrap_xmlrpc_method() accepts two new options: debug and return_on_fault
210
211
212 XML-RPC for PHP version 2.1 - 2006/08/28
213
214 This release corrects quite a few bugs and adds some interesting new features.
215 There is a minor security enhancement and overall speedup too.
216
217 It has been tested with PHP 4.0.5 up to 4.4.4 and 5.1.5.
218 Please note that 404pl1 is NOT supported, and has not been since 2.0.
219
220 *** PLEASE READ CAREFULLY BELOW ***
221
222 CHANGES THAT MIGHT AFFECT DEPLOYED APPLICATIONS:
223
224 The wrap_php_function and wrap_xmlrpc_method functions have been moved out of
225 the base library file xmlrpc.inc into a file of their own: xmlrpc_wrappers.inc.
226 You will have to include() / require() it in your scripts if you have been using
227 those functions.
228
229 For increased security, the automatic rebuilding of php object instances out of
230 received xmlrpc structs in wrap_xmlrpc_method() has been disabled (but it can be
231 optionally reenabled).
232
233 The constructor of xmlrpcval() values has seen major changes, and it will not
234 throw a php warning anymore when invoked using an unknown xmlrpc type: the
235 error will only be written to php error log. Also new xmlrpcval('true', 'boolean')
236 is not supported anymore.
237
238 MAJOR IMPROVEMENTS:
239
240 The new function php_xmlrpc_decode_xml() will take the xml representation of
241 either an xmlrpc request, response or single value and return the corresponding
242 php-xmlrpc object instance.
243
244 Both wrap_php_function() and wrap_xmlrpc_method() functions accept many more
245 options to fine tune their behaviour, including one to return the php code to
246 be saved and later used as standalone php script.
247
248 A new function wrap_xmlrpc_server() has been added, to wrap all (or some) of the
249 methods exposed by a remote xmlrpc server into a php class.
250
251 Lib internals have been modified to provide better support for grafting extra
252 functionality on top of it. Stay tuned for future releases of the EXTRAS package.
253
254 Last but not least a new file has been added: verify_compat.php, to help users
255 diagnose the level of compliance of the current php install with the library.
256
257 CHANGELOG IN DETAIL:
258
259 * fixed bug 1311927: client not playing nice with some proxy/firewall on ports != 80
260 * fixed bug 1334340: all ereg_ functions have been replaced with corresponding preg_
261 * fixed bug: wrong handling of 'deflate' http encoding, both server and client side
262 * fixed bug: sending compressed responses when php output compression is enabled was not working
263 * fixed bug: addarray() and addstruct() where not returning 1 when adding data to already initialized values
264 * fixed bug: non-ascii chars used in struct element names where not being encoded correctly
265 * restored compatibility with php 4.0.5 (for those poor souls still stuck on it)
266 * server->service() now returns either the payload or xmlrpcresp instance
267 * server->add_to_map() now accepts methods with no param definitions
268 * added new function: php_xmlrpc_decode_xml()
269 * added new function: wrap_xmlrpc_server()
270 * major improvements and security enhancements to wrap_php_function() and wrap_xmlrpc_method()
271 * documentation for single parameters of exposed methods can be added to the dispatch map
272   (and turned into html docs in conjunction with a future release of the extras package)
273 * full response payload is saved into xmlrpcresp object for further debugging
274 * stricter parsing of incoming xmlrpc messages: two more invalid cases are now detected
275   (double data element inside array and struct/array after scalar inside value element)
276 * debugger can now generate code that wraps a remote method into php function (works for jsonrpc, too)
277 * debugger has better support for being activated via a single GET call (for integration into other tools?)
278 * more logging of errors in a lot of situations
279 * javadoc documentation of lib files almost complete
280 * the usual amount of new testcases in the testsuite
281 * many performance tweaks and code cleanups
282 * added foundation for emulating the API of the xmlrpc extension (extras package needed)
283
284
285 XML-RPC for PHP version 2.0 - 2006/04/24
286
287 I'm pleased to announce XML-RPC for PHP version 2.0, final.
288
289 With respect to the last release candidate, this release corrects a few small
290 bugs and adds a couple of new features: more authentication options (digest and
291 ntlm for servers, ntlm for proxies, and some https custom certificates stuff);
292 all the examples have been reviewed and some demo files added,
293 including a ready-made xmlrpc proxy (useful e.g. for ajax calls, when the xmlrpc
294 client is a browser); the server logs more warning messages for incorrect situations;
295 both client and server are more tolerant of commonly-found mistakes.
296 The debugger has been upgraded to reflect the new client capabilities.
297
298 In greater detail:
299
300 * fixed bug: method xmlrpcval::structmemexists($value) would not work
301 * fixed bug: wrap_xmlrpc_method would fail if invoked with a client object that
302   has return_type=phpvals
303 * fixed bug: in case of call to client::multicall without fallback and server error
304 * fixed bug: recursive serialization of xmlrpcvals loosing specified UTF8 charset
305 * fixed bug: serializing to ISO-8859-1 with php 5 would raise an error if non-ascii
306   chars where found when decoding
307 * new: client can use NTLM and Digest authentication methods for https and http 1.1
308   connections; authentication to proxy can be set to NTLM, too
309 * new: server tolerates user functions returning a single xmlrpcval object instead
310   of an xmlrpcresp
311 * new: server does more checks for presence and correct return type of user
312   coded method handling functions, and logs inconsistencies to php error log
313 * new: client method SetCaCertificate($cert, $is_dir) to validate server against
314 * new: both server and client tolerate receiving 'true' and 'false' for bool values
315   (which btw are not valid according to the xmlrpc spec)
316
317
318 XML-RPC for PHP version 2.0RC3 - 2006/01/22
319
320 This release corrects a few bugs and adds some interesting new features.
321 It has been tested with PHP up to 4.4.2 and 5.1.2.
322
323 * fixed bug: server not recognizing clients that declare support for http compression
324 * fixed bug: serialization of new xmlrpcval (8, 'string') when internal encoding
325   set to UTF-8
326 * fixed bug: serialization of new xmlrpcval ('hello', 'int') would produce
327   invalid xml-rpc
328 * new: let the server accept 'class::method' syntax in the dispatch map
329 * new: php_xmlrpc_decode() can decode xmlrpcmessage objects
330 * new: both client and server can specify a charset to be used for serializing
331   values instead of the default 'US-ASCII+xml-entities-for-other-characters'.
332   Values allowed: ISO-8859-1 and UTF-8
333 * new: the server object can register 'plain' php functions instead of functions
334   that accept a single parameter of type xmlrpcmsg. Faster, uses less memory
335   (but comes with minor drawbacks as well, read the manual for more details)
336 * new: client::setDebug(2) can be used to have the request payload printed to
337   screen before being sent
338 * new: server::service($data) lets user parse data other than POST body, for
339   easier testing / subclassing
340 * changed: framework-generated debug messages are sent back by the server base64
341   encoded, to avoid any charset/xml compatibility problem
342 * other minor fixes
343
344 The usual refactoring of a lot of (private) methods has taken place, with new
345 parameters added to some functions.
346 Javadoc documentation has been improved a lot.
347 The HTML documentation has been shuffled around a bit, hoping to give it a more
348 logical organization.
349
350 The experimental support for the JSON protocol has been removed, and will be
351 packaged as a separate download with some extra very interesting stuff (human
352 readable auto-generated documentation, anyone?).
353
354
355 XML-RPC for PHP version 2.0RC2 - 2005/11/22
356
357 This release corrects a few bugs and adds basically one new method for better
358 HTTPS support:
359
360  * fixed two bugs that prevented xmlrpc calls to take place over https
361  * fixed two bugs that prevented proper recognition of xml character set
362    when it was declared inside the xml prologue
363  * added xmlrpc_client::setKey($key, $keypass) method, to allow using client
364    side certificates for https connections
365  * fixed bug that prevented proper serialization of string xmlrpcvals when
366    $xmlrpc_internalencoding was set to UTF-8
367  * fixed bug in xmlrpc_server::echoInput() (and marked method as deprecated)
368  * correctly set cookies/http headers into xmlrpcresp objects even when the
369    send() method call fails for some reason
370  * added a benchmark file in the testsuite directory
371
372 A couple of (private/protected) methods have been refactored, as well as a
373 couple of extra parameters added to some (private) functions - this has no
374 impact on the public API and should be of interest primarily to people extending
375 / subclassing the lib.
376
377 There is also new, PARTIAL support for the JSON-RPC protocol, implemented in
378 two files in the extras dir (more info about json-rpc at http://json-rpc.org)
379
380
381 XML-RPC for PHP version 2.0RC1 - 2005/10/03
382
383 I'm pleased to announce XML-RPC for PHP version 2.0, release candidate 1.
384
385 This release introduces so many new features it is almost impossible to list them
386 here, making the library finally on pair with, if not more advanced than, any other
387 similar offer (e.g. the PEAR XMLRPC package or the Incutio IXR library).
388 No, really, trust me.
389
390 The minimum supported PHP version is now 4.2 - natively - or 4.0.4pl1 - by usage of
391 a couple of compatibility classes (code taken from PEAR php_compat package).
392
393 The placement of files and directories in the distribution has been deeply modified,
394 in the hope of making it more clear, now that the file count has increased.
395 I hope you find it easy.
396
397 Support for "advanced" HTTP features such as cookies, proxies and keep-alives has
398 been added at last.
399
400 It is now much easier to convert between xmlrpcval objects and php values, and
401 in fact php_xmlrpc_encode and php_xmlrpc_decode are now the recommended methods
402 for all cases, except when encoding base64 data.
403
404 Two new (experimental) functions have been added, allowing automagic conversion
405 of a php function into an xmlrpc method to be exposed and vice-versa.
406
407 PHP objects can be now automatically serialized as xmlrpc struct values and
408 correctly deserialized on the other end of the transmission, provided that the
409 same class definition is present on both sides and no object members are of
410 type resource.
411
412 A lot of the existing class methods have been overloaded with extra parameters
413 or new functionality, and a few added ex-novo, making usage easier than ever.
414
415 A complete debugger solution is included in the distribution. It needs a web server
416 to run (a freely available version of the same debugger is accessible online, it
417 can be found at http://phpxmlrpc.sourceforge.net).
418
419 For a more detailed list of changes, please read carefully chapter 2 of the
420 included documentation, or, even better, take a look at the source code, which
421 is commented in javadoc style quite a bit.
422
423
424 XML-RPC for PHP version 1.2 - 2005/08/14
425
426 This removes all use of eval(), which is a potential security problem.
427 All users are encouraged to upgrade as soon as possible.
428 As of this release we are no longer php3-compatible.
429
430
431 XML-RPC for PHP version 1.1.1 - 2005/06/30
432
433 This is a security vulnerability fix release.
434 All users are invited to upgrade as soon as possible.
435
436
437 XML-RPC for PHP version 1.1 - 2005/05/03
438
439 I'm pleased to announce XML-RPC for PHP version 1.1
440 It's taken two years to get to the this point, but here we are, finally.
441
442 This is a bugfix and maintenance release. No major new features have been added.
443 All known bugs have been ironed out, unless fixing would have meant breaking
444 the API.
445 The code has been tested with PHP 3, 4 and 5, even tough PHP 4 is the main
446 development platform (and some warnings will be emitted when running PHP5).
447
448 Noteworthy changes include:
449
450  * do not clash any more with the EPI xmlrpc extension bundled with PHP 4 and 5
451  * fixed the unicode/charset problems that have been plaguing the lib for years
452  * proper parsing of int and float values prepended with zeroes or the '+' char
453  * accept float values in exponential notation
454  * configurable http user-agent string
455  * use the same timeout on client socket reads as used for connecting
456  * more explicative error messages in xmlrpcresponse in many cases
457  * much more tolerant parsing of malformed http responses from xmlrpc servers
458  * fixed memleak that prevented the client to be used in never-ending scripts
459  * parse bigger xmlrpc messages without crashing (1MB in size or more)
460  * be tolerant to xmlrpc responses generated on public servers that add
461    javascript advertising at the end of hosted content
462  * the lib generates quite a few less PHP warnings during standard operation
463
464 This is the last release that will support PHP 3.
465 The next release will include better support for PHP 5 and (possibly) a slew of
466 new features.
467
468 The changelog is available at:
469 http://cvs.sourceforge.net/viewcvs.py/phpxmlrpc/xmlrpc/ChangeLog?view=markup
470
471 Please report bugs to the XML-RPC PHP mailing list or to the sourceforge project
472 pages at http://sourceforge.net/projects/phpxmlrpc/
473
474
475 XML-RPC for PHP version 1.0
476
477 I'm pleased to announce XML-RPC for PHP version 1.0 (final). It's taken
478 two years to get to the 1.0 point, but here we are, finally.  The major change
479 is re-licensing with the BSD open source license, a move from the custom
480 license previously used.
481
482 After this release I expect to move the project to SourceForge and find
483 another primary maintainer for the code.  More details will follow to the
484 mailing list.
485
486 It can be downloaded from http://xmlrpc.usefulinc.com/php.html
487
488 Comprehensive documentation is available in the distribution, but you
489 can also browse it at http://xmlrpc.usefulinc.com/doc/
490
491 Bugfixes in this release include:
492
493  * Small fixes and tidying up.
494
495 New features include:
496
497  * experimental support for SSL via the curl extensions to PHP.  Needs
498    PHP 4.0.2 or greater, but not PHP 4.0.6 which has broken SSL support.
499
500 The changelog is available at: http://xmlrpc.usefulinc.com/ChangeLog.txt
501
502 Please report bugs to the XML-RPC PHP mailing list, of which more details are
503 available at http://xmlrpc.usefulinc.com/list.html, or to
504 <xmlrpc@usefulinc.com>.
505
506
507 XML-RPC for PHP version 1.0 beta 9
508
509 I'm pleased to announce XML-RPC for PHP version 1.0 beta 9. This is
510 is largely a bugfix release.
511
512 It can be downloaded from http://xmlrpc.usefulinc.com/php.html
513
514 Comprehensive documentation is available in the distribution, but you
515 can also browse it at http://xmlrpc.usefulinc.com/doc/
516
517 Bugfixes in this release include:
518
519  * Fixed string handling bug where characters between a </string>
520    and </value> tag were not ignored.
521
522  * Added in support for PHP's native boolean type.
523
524 New features include:
525
526  * new getval() method (experimental only) which has support for
527    recreating nested arrays.
528  * fledgling unit test suite
529  * server.php has support for basic interop test suite
530
531 The changelog is available at: http://xmlrpc.usefulinc.com/ChangeLog.txt
532
533 Please test this as hard as possible and report bugs to the XML-RPC PHP
534 mailing list, of which more details are available at
535 http://xmlrpc.usefulinc.com/list.html, or to <xmlrpc@usefulinc.com>.
536
537
538 XML-RPC for PHP version 1.0 beta 8
539
540 I'm pleased to announce XML-RPC for PHP version 1.0 beta 8.
541
542 This release fixes several bugs and adds a couple of new helper
543 functions. The most critical change in this release is that you can no
544 longer print debug info in comments inside a server method -- you must
545 now use the new xmlrpc_debugmsg() function.
546
547 It can be downloaded from http://xmlrpc.usefulinc.com/php.html
548
549 Comprehensive documentation is available in the distribution, but you
550 can also browse it at http://xmlrpc.usefulinc.com/doc/
551
552 Bugfixes in this release include:
553
554  * fixed whitespace handling in values
555  * correct sending of Content-length from the server
556
557 New features include:
558
559  * xmlrpc_debugmsg() method allows sending of debug info in comments in
560    the return payload from a server
561
562  * xmlrpc_encode() and xmlrpc_decode() translate between xmlrpcval
563    objects and PHP language arrays. They aren't suitable for all
564    datatypes, but can speed up coding in simple scenarios. Thanks to Dan
565    Libby for these.
566
567 The changelog is available at: http://xmlrpc.usefulinc.com/ChangeLog.txt
568
569 Please test this as hard as possible and report bugs to the XML-RPC PHP
570 mailing list, of which more details are available at
571 http://xmlrpc.usefulinc.com/list.html, or to <xmlrpc@usefulinc.com>.
572
573
574 XML-RPC for PHP version 1.0 beta 7
575
576 I'm pleased to announce XML-RPC for PHP version 1.0 beta 7. This is
577 fixes some critical bugs that crept in. If it shows itself to be stable
578 then it'll become the 1.0 release.
579
580 It can be downloaded from http://xmlrpc.usefulinc.com/php.html
581
582 Comprehensive documentation is available in the distribution, but you
583 can also browse it at http://xmlrpc.usefulinc.com/doc/
584
585 Bugfixes in this release include:
586
587  * Passing of booleans should now work as expected
588  * Dollar signs and backslashes in strings should pass OK
589  * addScalar() now works properly to append to array vals
590
591 New features include:
592
593  * Added support for HTTP Basic authorization through the
594    xmlrpc_client::setCredentials method.
595
596  * Added test script and method for verifying correct passing of
597          booleans
598
599 The changelog is available at: http://xmlrpc.usefulinc.com/ChangeLog.txt
600
601 Please test this as hard as possible and report bugs to the XML-RPC PHP
602 mailing list, of which more details are available at
603 http://xmlrpc.usefulinc.com/list.html, or to <xmlrpc@usefulinc.com>.
604
605
606 XML-RPC for PHP version 1.0 beta 6
607
608 I'm pleased to announce XML-RPC for PHP version 1.0 beta 6. This is the
609 final beta before the 1.0 release.
610
611 It can be downloaded from http://xmlrpc.usefulinc.com/php.html
612
613 Comprehensive documentation is available in the distribution, but you
614 can also browse it at http://xmlrpc.usefulinc.com/doc/
615
616 New features in this release include:
617
618  * Perl and Python test programs for the demo server
619  * Proper fault generation on a non-"200 OK" response from a remote host
620  * Bugfixed base64 decoding
621  * ISO8601 helper routines for translation to and from UNIX timestamps
622  * reorganization of code to allow eventual integration of alternative
623    transports
624
625 The changelog is available at: http://xmlrpc.usefulinc.com/ChangeLog.txt
626
627 Please test this as hard as possible and report bugs to the XML-RPC PHP
628 mailing list, of which more details are available at
629 http://xmlrpc.usefulinc.com/list.html, or to <xmlrpc@usefulinc.com>.