diff -r 5a6b6e770365 -r 68c69c656a2c web/lib/Zend/Service/Audioscrobbler.php --- a/web/lib/Zend/Service/Audioscrobbler.php Thu May 07 15:10:09 2015 +0200 +++ b/web/lib/Zend/Service/Audioscrobbler.php Thu May 07 15:16:02 2015 +0200 @@ -16,9 +16,9 @@ * @category Zend * @package Zend_Service * @subpackage Audioscrobbler - * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com) + * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License - * @version $Id: Audioscrobbler.php 24593 2012-01-05 20:35:02Z matthew $ + * @version $Id$ */ @@ -27,12 +27,14 @@ */ require_once 'Zend/Http/Client.php'; +/** @see Zend_Xml_Security */ +require_once 'Zend/Xml/Security.php'; /** * @category Zend * @package Zend_Service * @subpackage Audioscrobbler - * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com) + * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License */ class Zend_Service_Audioscrobbler @@ -69,9 +71,15 @@ { $this->set('version', '1.0'); - iconv_set_encoding('output_encoding', 'UTF-8'); - iconv_set_encoding('input_encoding', 'UTF-8'); - iconv_set_encoding('internal_encoding', 'UTF-8'); + if (PHP_VERSION_ID < 50600) { + iconv_set_encoding('output_encoding', 'UTF-8'); + iconv_set_encoding('input_encoding', 'UTF-8'); + iconv_set_encoding('internal_encoding', 'UTF-8'); + } else { + ini_set('output_encoding', 'UTF-8'); + ini_set('input_encoding', 'UTF-8'); + ini_set('default_charset', 'UTF-8'); + } } /** @@ -182,7 +190,7 @@ set_error_handler(array($this, '_errorHandler')); - if (!$simpleXmlElementResponse = simplexml_load_string($responseBody)) { + if (!$simpleXmlElementResponse = Zend_Xml_Security::scan($responseBody)) { restore_error_handler(); /** * @see Zend_Service_Exception @@ -640,7 +648,7 @@ * @param array $errcontext * @return void */ - protected function _errorHandler($errno, $errstr, $errfile, $errline, array $errcontext) + public function _errorHandler($errno, $errstr, $errfile, $errline, array $errcontext) { $this->_error = array( 'errno' => $errno,