mirror of
https://github.com/OCA/account-financial-tools.git
synced 2025-02-02 12:47:26 +02:00
Update README Code cleanup: remove @api.one, better error messages, remove call to MOD_NAME which was not defined any more Use account.menu_config_multi_currency as parent menu
93 lines
3.8 KiB
Python
93 lines
3.8 KiB
Python
# -*- coding: utf-8 -*-
|
|
# © 2009 Camptocamp
|
|
# © 2009 Grzegorz Grzelak
|
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
|
|
|
from .currency_getter_interface import CurrencyGetterInterface
|
|
|
|
from datetime import datetime
|
|
from lxml import etree
|
|
|
|
import logging
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
|
|
class ECBGetter(CurrencyGetterInterface):
|
|
"""Implementation of Currency_getter_factory interface
|
|
for ECB service
|
|
"""
|
|
code = 'ECB'
|
|
name = 'European Central Bank'
|
|
supported_currency_array = [
|
|
"AUD", "BGN", "BRL", "CAD", "CHF", "CNY", "CZK", "DKK", "EUR", "GBP",
|
|
"HKD", "HRK", "HUF", "IDR", "ILS", "INR", "JPY", "KRW", "LTL", "MXN",
|
|
"MYR", "NOK", "NZD", "PHP", "PLN", "RON", "RUB", "SEK", "SGD", "THB",
|
|
"TRY", "USD", "ZAR"]
|
|
|
|
def rate_retrieve(self, dom, ns, curr):
|
|
"""Parse a dom node to retrieve-
|
|
currencies data
|
|
|
|
"""
|
|
res = {}
|
|
xpath_curr_rate = ("/gesmes:Envelope/def:Cube/def:Cube/"
|
|
"def:Cube[@currency='%s']/@rate") % (curr.upper())
|
|
res['rate_currency'] = float(
|
|
dom.xpath(xpath_curr_rate, namespaces=ns)[0]
|
|
)
|
|
return res
|
|
|
|
def get_updated_currency(self, currency_array, main_currency,
|
|
max_delta_days):
|
|
"""implementation of abstract method of Curreny_getter_interface"""
|
|
url = 'http://www.ecb.europa.eu/stats/eurofxref/eurofxref-daily.xml'
|
|
# Important : as explained on the ECB web site, the currencies are
|
|
# at the beginning of the afternoon ; so, until 3 p.m. Paris time
|
|
# the currency rates are the ones of trading day N-1
|
|
# http://www.ecb.europa.eu/stats/exchange/eurofxref/html/index.en.html
|
|
|
|
# We do not want to update the main currency
|
|
if main_currency in currency_array:
|
|
currency_array.remove(main_currency)
|
|
_logger.debug("ECB currency rate service : connecting...")
|
|
rawfile = self.get_url(url)
|
|
dom = etree.fromstring(rawfile)
|
|
_logger.debug("ECB sent a valid XML file")
|
|
ecb_ns = {
|
|
'gesmes': 'http://www.gesmes.org/xml/2002-08-01',
|
|
'def': 'http://www.ecb.int/vocabulary/2002-08-01/eurofxref'
|
|
}
|
|
rate_date = dom.xpath('/gesmes:Envelope/def:Cube/def:Cube/@time',
|
|
namespaces=ecb_ns)[0]
|
|
# Don't use DEFAULT_SERVER_DATE_FORMAT here, because it's
|
|
# the format of the XML of ECB, not the format of Odoo server !
|
|
rate_date_datetime = datetime.strptime(rate_date, '%Y-%m-%d')
|
|
self.check_rate_date(rate_date_datetime, max_delta_days)
|
|
# We dynamically update supported currencies
|
|
self.supported_currency_array = dom.xpath(
|
|
"/gesmes:Envelope/def:Cube/def:Cube/def:Cube/@currency",
|
|
namespaces=ecb_ns
|
|
)
|
|
self.supported_currency_array.append('EUR')
|
|
_logger.debug("Supported currencies = %s " %
|
|
self.supported_currency_array)
|
|
self.validate_cur(main_currency)
|
|
if main_currency != 'EUR':
|
|
main_curr_data = self.rate_retrieve(dom, ecb_ns, main_currency)
|
|
for curr in currency_array:
|
|
self.validate_cur(curr)
|
|
if curr == 'EUR':
|
|
rate = 1 / main_curr_data['rate_currency']
|
|
else:
|
|
curr_data = self.rate_retrieve(dom, ecb_ns, curr)
|
|
if main_currency == 'EUR':
|
|
rate = curr_data['rate_currency']
|
|
else:
|
|
rate = (curr_data['rate_currency'] /
|
|
main_curr_data['rate_currency'])
|
|
self.updated_currency[curr] = rate
|
|
_logger.debug(
|
|
"Rate retrieved : 1 %s = %s %s" % (main_currency, rate, curr)
|
|
)
|
|
return self.updated_currency, self.log_info
|