X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=gl%2Fincludes%2Fdb%2Fgl_db_rates.inc;h=0c9ae6863b5d81d572f404ddff4789bbf7c37322;hb=c15a2e092043303fc99080fe8bb4f33475ec4812;hp=cba2e5afe2bcaef7ca7244521d86fd9b42c8b220;hpb=f12dbe7523bb1abc6cd69b009ef8f0be838f5348;p=fa-stable.git
diff --git a/gl/includes/db/gl_db_rates.inc b/gl/includes/db/gl_db_rates.inc
index cba2e5af..0c9ae686 100644
--- a/gl/includes/db/gl_db_rates.inc
+++ b/gl/includes/db/gl_db_rates.inc
@@ -1,15 +1,15 @@
.
+***********************************************************************/
//---------------------------------------------------------------------------------------------
-
function get_exchange_rate($rate_id)
{
$sql = "SELECT * FROM ".TB_PREF."exchange_rates WHERE id=$rate_id";
@@ -74,32 +74,44 @@ function delete_exchange_rate($rate_id)
function get_ecb_rate($curr_b)
{
$curr_a = get_company_pref('curr_default');
- $ecb_filename = 'http://www.ecb.int/stats/eurofxref/eurofxref-daily.xml';
- $handle = @fopen($ecb_filename, 'rb');
+ $ecb_filename = '/stats/eurofxref/eurofxref-daily.xml';
+ $ecb_site = 'www.ecb.int';
$contents = '';
- if ($handle)
- {
- do
- {
- $data = @fread( $handle, 4096 );
- if ( strlen ( $data ) == 0 )
- break;
- $contents .= $data; // with this syntax only text will be translated, whole text with htmlspecialchars($data)
- }
- while (true);
- @fclose( $handle );
- } // end handle
- else
- {
- $ch = curl_init();
- curl_setopt ($ch, CURLOPT_URL, $ecb_filename);
- curl_setopt ($ch, CURLOPT_COOKIEJAR, "cookie.txt");
- curl_setopt ($ch, CURLOPT_HEADER, 0);
- curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);
- curl_setopt ($ch, CURLOPT_TIMEOUT, 120);
- $contents = curl_exec ($ch);
- curl_close($ch);
+
+ if (function_exists('curl_init'))
+ { // first check with curl as we can set short timeout;
+ $retry = 1;
+ do {
+ $ch = curl_init();
+ curl_setopt ($ch, CURLOPT_URL, 'http://'.$ecb_site.$ecb_filename);
+ curl_setopt ($ch, CURLOPT_COOKIEJAR, "cookie.txt");
+ curl_setopt ($ch, CURLOPT_HEADER, 0);
+ curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
+ curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);
+ curl_setopt ($ch, CURLOPT_TIMEOUT, 3);
+ $contents = curl_exec ($ch);
+ curl_close($ch);
+ // due to resolver bug in some curl versions (e.g. 7.15.5)
+ // try again for constant IP.
+ $ecb_site="195.128.2.97";
+ } while( ($contents == '') && $retry--);
+
+ } else {
+ $handle = @fopen("http://".$ecb_site.$ecb_filename, 'rb');
+ if ($handle) {
+ do
+ {
+ $data = @fread( $handle, 4096 );
+ if ( strlen ( $data ) == 0 )
+ break;
+ $contents .= $data; // with this syntax only text will be translated, whole text with htmlspecialchars($data)
+ }
+ while (true);
+ @fclose( $handle );
+ } // end handle
+ }
+ if (!$contents) {
+ display_warning(_('Cannot retrieve currency rate from ECB page. Please set the rate manually.'));
}
$contents = str_replace (" |i";
@@ -119,6 +131,6 @@ function get_ecb_rate($curr_b)
$val = 0;
}
return $val;
-} // end function get_ecb_rate
+} // end function get_ecb_rate
?>
\ No newline at end of file