// how often do we need to know this..?
// let's assume we do it once a week..
$x = DB_DataObject::Factory('core_curr_rate');
- $x->whereAdd("to_dt > NOW() AND curr != ''");// ingore crap data.
-
+ $x->whereAdd('to_dt > NOW()');
if ($x->count()) {
// got some data for beyond today..
return false;
}
- $dom = simplexml_load_file($target);
+ $dom = simplexml_load_string($f);
$rates['EUR'] = 1.0;
foreach($dom->Cube->Cube->Cube as $c) {
}
$rates['RMB'] = $rates['CNY'] ;
- foreach($rates as $cur=>$euro) {
+ foreach($rates as $cur=>$in_euro) {
- $rate = $this->rates['USD'] * $euro;
+ $rate = (1.0 / $rates['USD']) * $in_euro;
$ov = DB_DataObject::Factory('core_curr_rate');
$ov->curr = $cur;
- $nl = clone($x);
+ $nl = clone($ov);
$ov->orderBy('to_dt DESC');
$ov->limit(1);
if ($ov->rate == $rate) {
// modify the old one to expire
$oo = clone($ov);
- $ov->to_dt = $nv->from_dt;
+ $ov->to_dt = $nl->from_dt;
$ov->update($oo);
continue;
}
// crappy error handling..
if ($fr === false) {
- $fr = 1;
+ return false;
}
if ($tr === false) {
- $tr = 1;
+ return false;
}
return ((1.0 / $fr) * $val) * $tr;
}
+ function currentRates()
+ {
+ $this->loadRates();
+ // DB_DataObject::debugLevel(1);
+ $c = DB_DAtaObject::factory('core_curr_rate');
+ $c->whereAdd('from_dt < NOW() AND to_dt > NOW()');
+ $c->find();
+ $ret = array();
+ while($c->fetch()) {
+ $ret[$c->curr] = $c->rate;
+ }
+ return $ret;
+
+
+
+ }
}