TimeTrex/classes/pear/Services/ExchangeRates/Rates_ECB.php

108 lines
4.0 KiB
PHP
Raw Permalink Normal View History

2022-12-13 07:10:06 +01:00
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4: */
// +----------------------------------------------------------------------+
// | PHP version 4 |
// +----------------------------------------------------------------------+
// | Copyright (c) 1997-2003 The PHP Group |
// +----------------------------------------------------------------------+
// | This source file is subject to version 2.0 of the PHP license, |
// | that is bundled with this package in the file LICENSE, and is |
// | available through the world-wide-web at |
// | http://www.php.net/license/2_02.txt. |
// | If you did not receive a copy of the PHP license and are unable to |
// | obtain it through the world-wide-web, please send a note to |
// | license@php.net so we can mail you a copy immediately. |
// +----------------------------------------------------------------------+
// | Author: Marshall Roch <marshall@exclupen.com> |
// +----------------------------------------------------------------------+
//
// $Id: Rates_ECB.php,v 1.2 2005/06/23 07:44:12 cross Exp $
/**
* Exchange rate driver - European Central Bank
*
* The reference rates are based on the regular daily concertation
* procedure between central banks within and outside the European System
* of Central Banks, which normally takes place at 2.15 p.m. ECB time (CET).
* The reference exchange rates are published both by electronic market
* information providers and on the ECB's website shortly after the
* concertation procedure has been completed.
*
* @link http://www.ecb.int/stats/eurofxref/eurofxref-xml.html About the feed
* @link http://www.ecb.int/copy/copy01.htm IMPORTANT COPYRIGHT INFORMATION
*
* @author Marshall Roch <marshall@exclupen.com>
* @copyright Copyright 2003 Marshall Roch
* @license http://www.php.net/license/2_02.txt PHP License 2.0
* @package Services_ExchangeRates
*/
/**
* Include common functions to handle cache and fetch the file from the server
*/
require_once 'Services/ExchangeRates/Common.php';
/**
* European Central Bank Exchange Rate Driver
*
* @package Services_ExchangeRates
*/
class Services_ExchangeRates_Rates_ECB extends Services_ExchangeRates_Common {
/**
* URL of XML feed
* @access private
* @var string
*/
var $_feedXMLUrl = 'http://www.ecb.int/stats/eurofxref/eurofxref-daily.xml';
/**
* Downloads exchange rates in terms of the Euro from the European Central Bank. This
* information is updated daily, and is cached by default for 1 hour.
*
* Returns a multi-dimensional array containing:
* 'rates' => associative array of currency codes to exchange rates
* 'source' => URL of feed
* 'date' => date feed last updated, pulled from the feed (more reliable than file mod time)
*
* @link http://www.ecb.int/stats/eurofxref/ HTML version
* @link http://www.ecb.int/stats/eurofxref/eurofxref-daily.xml XML version
*
* @param int Length of time to cache (in seconds)
* @return array Multi-dimensional array
*/
function retrieve($cacheLength, $cacheDir) {
// IMPORTANT: defines Euro mapping. Without this, you can't convert
// to or from the Euro!
$return['date'] = NULL;
$return['rates'] = array('EUR' => 1.0);
$return['source'] = $this->_feedXMLUrl;
// retrieve the feed from the server or cache
$root = $this->retrieveXML($this->_feedXMLUrl, $cacheLength, $cacheDir);
if ( is_object( $root ) ) {
// set date published
$return['date'] = $root->children[5]->children[1]->attributes['time'];
// get down to array of exchange rates
$xrates = $root->children[5]->children[1]->children;
// loop through and put them into an array
foreach ($xrates as $rateinfo) {
if ($rateinfo->name == 'Cube') {
$return['rates'][$rateinfo->attributes['currency']] = $rateinfo->attributes['rate'];
}
}
}
return $return;
}
}
?>