Skip to content
CHANGELOG.md 2.47 KiB
Newer Older
# API changes

This library aims to provide a stable and reliable class for integration into other applications, avoiding backwards-incompatible changes, but that cannot always be guaranteed.

This file lists all major changes and additions to the PHP API for convenience.  "API" means the PHP class only; i.e., not the Mollom [REST API].
2013-11-09: Any `4xx` request error response code is now returned to application.

* All client implementations need to account for all possible `4xx` errors now; primarily:
    * `400 Bad Request` (→ `Mollom::REQUEST_ERROR`)
    * `401 Unauthorized` (→ `Mollom::AUTH_ERROR`)
    * `404 Not Found`
* `Mollom::query()` previously
    * retried a request despite a `4xx` error (except for `404`).
    * returned either `Mollom::REQUEST_ERROR` (`400`) or `Mollom::NETWORK_ERROR` (`900`).
* For example, a `404 Not Found` error may be returned by the Site API of the [REST Testing API], when trying to access a site resource that has vanished.

2013-04-23: Visibility of `Mollom::query()` changed from `protected` to `public`.
Daniel Kudwien's avatar
Daniel Kudwien committed

* Only affects classes that are overriding the `Mollom::query()` method (rare).
* Simply change your overridden method accordingly.
* Cause: Custom and new/experimental Mollom API calls should not require dedicated class methods to work.

2012-12-14: `400 Bad (Client) Request` error handling.

* `Mollom::handleRequest()` throws a new `MollomBadRequestException` in case the local system time diverges too much from UTC.
* `Mollom::query()` returns a new possible `Mollom::REQUEST_ERROR` code (400) in case the local system time diverges too much from UTC.
* Cause: Too many support requests from users reporting authentication failures, which are caused by a local server time that is not synchronized with UTC.  The maximum allowed time offset is `Mollom::TIME_OFFSET_MAX`.
* All client implementations should check for this new error code (in the same places where authentication errors are handled already) and conditionally log and output a corresponding error message to site administrators along the lines of:

  > The server time of this site is incorrect. The time of the operating system is not synchronized with the Coordinated Universal Time (UTC), which prevents a successful authentication with Mollom. The maximum allowed offset is @minutes minutes. Please consult your hosting provider or server operator to correct the server time.
[REST API]: http://mollom.com/api
[REST Testing API]: http://mollom.com/api#api-test