| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2022-10-16 19:29:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  | /* | 
					
						
							|  |  |  |  * ConvertsExchangeRates.php | 
					
						
							|  |  |  |  * Copyright (c) 2022 james@firefly-iii.org | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-16 19:29:53 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  | namespace FireflyIII\Support\Http\Api; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2022-06-07 19:24:08 +02:00
										 |  |  | use DateTimeInterface; | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  | use FireflyIII\Models\CurrencyExchangeRate; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionCurrency; | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Trait ConvertsExchangeRates | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | trait ConvertsExchangeRates | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-06-07 19:24:08 +02:00
										 |  |  |     private ?bool $enabled = null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-29 19:42:26 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param array $set | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-12-29 19:42:26 +01:00
										 |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function cerChartSet(array $set): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (null === $this->enabled) { | 
					
						
							|  |  |  |             $this->getPreference(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // if not enabled, return the same array but without conversion:
 | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         return $set; | 
					
						
							|  |  |  |         $this->enabled = false; | 
					
						
							| 
									
										
										
										
											2022-12-29 19:42:26 +01:00
										 |  |  |         if (false === $this->enabled) { | 
					
						
							|  |  |  |             $set['converted'] = false; | 
					
						
							|  |  |  |             return $set; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $set['converted'] = true; | 
					
						
							|  |  |  |         /** @var TransactionCurrency $native */ | 
					
						
							|  |  |  |         $native   = app('amount')->getDefaultCurrency(); | 
					
						
							|  |  |  |         $currency = $this->getCurrency((int)$set['currency_id']); | 
					
						
							|  |  |  |         if ($native->id === $currency->id) { | 
					
						
							|  |  |  |             $set['native_id']             = (string)$currency->id; | 
					
						
							|  |  |  |             $set['native_code']           = $currency->code; | 
					
						
							|  |  |  |             $set['native_symbol']         = $currency->symbol; | 
					
						
							|  |  |  |             $set['native_decimal_places'] = $currency->decimal_places; | 
					
						
							|  |  |  |             return $set; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($set['entries'] as $date => $entry) { | 
					
						
							|  |  |  |             $carbon = Carbon::createFromFormat(DateTimeInterface::ATOM, $date); | 
					
						
							|  |  |  |             $rate   = $this->getRate($currency, $native, $carbon); | 
					
						
							|  |  |  |             $rate   = '0' === $rate ? '1' : $rate; | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |             app('log')->debug(sprintf('bcmul("%s", "%s")', (string)$entry, $rate)); | 
					
						
							| 
									
										
										
										
											2022-12-29 19:42:26 +01:00
										 |  |  |             $set['entries'][$date] = (float)bcmul((string)$entry, $rate); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $set; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-07 19:24:08 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @return void | 
					
						
							| 
									
										
										
										
											2022-06-07 19:24:08 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |     private function getPreference(): void | 
					
						
							| 
									
										
										
										
											2023-05-29 13:56:55 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         $this->enabled = config('cer.currency_conversion'); | 
					
						
							| 
									
										
										
										
											2022-06-07 19:24:08 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param int $currencyId | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |      * @return TransactionCurrency | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getCurrency(int $currencyId): TransactionCurrency | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = TransactionCurrency::find($currencyId); | 
					
						
							|  |  |  |         if (null === $result) { | 
					
						
							|  |  |  |             return app('amount')->getDefaultCurrency(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param TransactionCurrency $from | 
					
						
							|  |  |  |      * @param TransactionCurrency $to | 
					
						
							|  |  |  |      * @param Carbon              $date | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |     private function getRate(TransactionCurrency $from, TransactionCurrency $to, Carbon $date): string | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         // first attempt:
 | 
					
						
							|  |  |  |         $rate = $this->getFromDB((int)$from->id, (int)$to->id, $date->format('Y-m-d')); | 
					
						
							|  |  |  |         if (null !== $rate) { | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |             return $rate; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |         // no result. perhaps the other way around?
 | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         $rate = $this->getFromDB((int)$to->id, (int)$from->id, $date->format('Y-m-d')); | 
					
						
							|  |  |  |         if (null !== $rate) { | 
					
						
							|  |  |  |             return bcdiv('1', $rate); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // if nothing in place, fall back on the rate for $from to EUR
 | 
					
						
							|  |  |  |         $first  = $this->getEuroRate($from, $date); | 
					
						
							|  |  |  |         $second = $this->getEuroRate($to, $date); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // combined (if present), they can be used to calculate the necessary conversion rate.
 | 
					
						
							|  |  |  |         if ('0' === $first || '0' === $second) { | 
					
						
							|  |  |  |             return '0'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $second = bcdiv('1', $second); | 
					
						
							|  |  |  |         return bcmul($first, $second); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param int    $from | 
					
						
							|  |  |  |      * @param int    $to | 
					
						
							|  |  |  |      * @param string $date | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getFromDB(int $from, int $to, string $date): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $key = sprintf('cer-%d-%d-%s', $from, $to, $date); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty($key); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2023-08-06 07:04:09 +02:00
										 |  |  |             $rate = $cache->get(); | 
					
						
							|  |  |  |             if ('' === $rate) { | 
					
						
							|  |  |  |                 return null; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return $rate; | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-08-06 07:04:09 +02:00
										 |  |  |         app('log')->debug(sprintf('Going to get rate #%d->#%d (%s) from DB.', $from, $to, $date)); | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |         /** @var CurrencyExchangeRate $result */ | 
					
						
							|  |  |  |         $result = auth()->user() | 
					
						
							|  |  |  |                         ->currencyExchangeRates() | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |                         ->where('from_currency_id', $from) | 
					
						
							|  |  |  |                         ->where('to_currency_id', $to) | 
					
						
							|  |  |  |                         ->where('date', '<=', $date) | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |                         ->orderBy('date', 'DESC') | 
					
						
							|  |  |  |                         ->first(); | 
					
						
							| 
									
										
										
										
											2023-08-06 07:04:09 +02:00
										 |  |  |         $rate   = (string)$result?->rate; | 
					
						
							|  |  |  |         $cache->store($rate); | 
					
						
							|  |  |  |         if ('' === $rate) { | 
					
						
							|  |  |  |             return null; | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-08-06 07:04:09 +02:00
										 |  |  |         return $rate; | 
					
						
							| 
									
										
										
										
											2023-05-29 13:56:55 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param TransactionCurrency $currency | 
					
						
							|  |  |  |      * @param Carbon              $date | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |     private function getEuroRate(TransactionCurrency $currency, Carbon $date): string | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         $euroId = $this->getEuroId(); | 
					
						
							|  |  |  |         if ($euroId === (int)$currency->id) { | 
					
						
							|  |  |  |             return '1'; | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         $rate = $this->getFromDB((int)$currency->id, $euroId, $date->format('Y-m-d')); | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         if (null !== $rate) { | 
					
						
							| 
									
										
										
										
											2023-07-28 16:14:55 +02:00
										 |  |  |             //            app('log')->debug(sprintf('Rate for %s to EUR is %s.', $currency->code, $rate));
 | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |             return $rate; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         $rate = $this->getFromDB($euroId, (int)$currency->id, $date->format('Y-m-d')); | 
					
						
							|  |  |  |         if (null !== $rate) { | 
					
						
							|  |  |  |             $rate = bcdiv('1', $rate); | 
					
						
							| 
									
										
										
										
											2023-07-28 16:14:55 +02:00
										 |  |  |             //            app('log')->debug(sprintf('Inverted rate for %s to EUR is %s.', $currency->code, $rate));
 | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  |             return $rate; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         // grab backup values from config file:
 | 
					
						
							|  |  |  |         $backup = config(sprintf('cer.rates.%s', $currency->code)); | 
					
						
							|  |  |  |         if (null !== $backup) { | 
					
						
							|  |  |  |             $backup = bcdiv('1', (string)$backup); | 
					
						
							|  |  |  |             // app('log')->debug(sprintf('Backup rate for %s to EUR is %s.', $currency->code, $backup));
 | 
					
						
							|  |  |  |             return $backup; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-28 16:14:55 +02:00
										 |  |  |         //        app('log')->debug(sprintf('No rate for %s to EUR.', $currency->code));
 | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |         return '0'; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getEuroId(): int | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty('cer-euro-id'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return $cache->get(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $euro = TransactionCurrency::whereCode('EUR')->first(); | 
					
						
							|  |  |  |         if (null === $euro) { | 
					
						
							|  |  |  |             throw new FireflyException('Cannot find EUR in system, cannot do currency conversion.'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $cache->store((int)$euro->id); | 
					
						
							|  |  |  |         return (int)$euro->id; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * For a sum of entries, get the exchange rate to the native currency of | 
					
						
							|  |  |  |      * the user. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $entries | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @return array | 
					
						
							| 
									
										
										
										
											2023-08-01 11:15:19 +02:00
										 |  |  |      * @deprecated | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function cerSum(array $entries): array | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-08-01 11:15:19 +02:00
										 |  |  |         die('do not use me, needs refactor'); | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |         if (null === $this->enabled) { | 
					
						
							|  |  |  |             $this->getPreference(); | 
					
						
							| 
									
										
										
										
											2023-02-22 18:14:14 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // if false, return the same array without conversion info
 | 
					
						
							|  |  |  |         if (false === $this->enabled) { | 
					
						
							|  |  |  |             $return = []; | 
					
						
							|  |  |  |             /** @var array $entry */ | 
					
						
							|  |  |  |             foreach ($entries as $entry) { | 
					
						
							|  |  |  |                 $entry['converted'] = false; | 
					
						
							|  |  |  |                 $return[]           = $entry; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return $return; | 
					
						
							| 
									
										
										
										
											2023-02-22 18:14:14 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var TransactionCurrency $native */ | 
					
						
							|  |  |  |         $native = app('amount')->getDefaultCurrency(); | 
					
						
							|  |  |  |         $return = []; | 
					
						
							|  |  |  |         /** @var array $entry */ | 
					
						
							|  |  |  |         foreach ($entries as $entry) { | 
					
						
							|  |  |  |             $currency = $this->getCurrency((int)$entry['id']); | 
					
						
							|  |  |  |             if ($currency->id !== $native->id) { | 
					
						
							|  |  |  |                 $amount                         = $this->convertAmount($entry['sum'], $currency, $native); | 
					
						
							|  |  |  |                 $entry['converted']             = true; | 
					
						
							|  |  |  |                 $entry['native_sum']            = $amount; | 
					
						
							|  |  |  |                 $entry['native_id']             = (string)$native->id; | 
					
						
							|  |  |  |                 $entry['native_name']           = $native->name; | 
					
						
							|  |  |  |                 $entry['native_symbol']         = $native->symbol; | 
					
						
							|  |  |  |                 $entry['native_code']           = $native->code; | 
					
						
							|  |  |  |                 $entry['native_decimal_places'] = $native->decimal_places; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if ($currency->id === $native->id) { | 
					
						
							|  |  |  |                 $entry['converted']             = false; | 
					
						
							|  |  |  |                 $entry['native_sum']            = $entry['sum']; | 
					
						
							|  |  |  |                 $entry['native_id']             = (string)$native->id; | 
					
						
							|  |  |  |                 $entry['native_name']           = $native->name; | 
					
						
							|  |  |  |                 $entry['native_symbol']         = $native->symbol; | 
					
						
							|  |  |  |                 $entry['native_code']           = $native->code; | 
					
						
							|  |  |  |                 $entry['native_decimal_places'] = $native->decimal_places; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $return[] = $entry; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-04 13:29:19 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * @param string              $amount | 
					
						
							| 
									
										
										
										
											2023-07-04 13:29:19 +02:00
										 |  |  |      * @param TransactionCurrency $from | 
					
						
							|  |  |  |      * @param TransactionCurrency $to | 
					
						
							| 
									
										
										
										
											2023-07-15 16:02:42 +02:00
										 |  |  |      * @param Carbon|null         $date | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2023-07-04 13:29:19 +02:00
										 |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |     private function convertAmount(string $amount, TransactionCurrency $from, TransactionCurrency $to, ?Carbon $date = null): string | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-07-25 09:01:44 +02:00
										 |  |  |         app('log')->debug(sprintf('Converting %s from %s to %s', $amount, $from->code, $to->code)); | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |         $date = $date ?? today(config('app.timezone')); | 
					
						
							|  |  |  |         $rate = $this->getRate($from, $to, $date); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return bcmul($amount, $rate); | 
					
						
							| 
									
										
										
										
											2023-02-22 18:14:14 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-06-06 14:40:19 +02:00
										 |  |  | } |