Easy.Tools.Finance.TCMB
1.0.4
dotnet add package Easy.Tools.Finance.TCMB --version 1.0.4
NuGet\Install-Package Easy.Tools.Finance.TCMB -Version 1.0.4
<PackageReference Include="Easy.Tools.Finance.TCMB" Version="1.0.4" />
<PackageVersion Include="Easy.Tools.Finance.TCMB" Version="1.0.4" />
<PackageReference Include="Easy.Tools.Finance.TCMB" />
paket add Easy.Tools.Finance.TCMB --version 1.0.4
#r "nuget: Easy.Tools.Finance.TCMB, 1.0.4"
#:package Easy.Tools.Finance.TCMB@1.0.4
#addin nuget:?package=Easy.Tools.Finance.TCMB&version=1.0.4
#tool nuget:?package=Easy.Tools.Finance.TCMB&version=1.0.4
#Easy.Tools.Finance.TCMB
Easy.Tools.Finance.TCMB is a high-performance, enterprise-ready .NET library designed to fetch official exchange rates from the Central Bank of the Republic of Turkey (TCMB/CBRT).
It supports fetching both daily and historical rates, handles XML parsing efficiently, and includes built-in resilience mechanisms.
Features
- ** High Performance:** Uses Static XML Serializer caching to minimize memory pressure and prevent memory leaks.
- ** Historical Data:** Built-in support for fetching rates from past dates (automatically handles TCMB's archive URL structure).
- ** Resilience:** Built-in Retry Policy with exponential backoff for handling network glitches.
- ** Culture Safe:** Parsing logic is strictly Invariant Culture, ensuring stability regardless of the server's regional settings.
- ** Easy Integration:** Single-line integration with
IServiceCollection(Dependency Injection). - ** Async & Cancellable:** Full support for
async/awaitandCancellationToken.
Installation
Install via NuGet Package Manager:
Install-Package Easy.Tools.Finance.TCMB
Or via .NET CLI:
dotnet add package Easy.Tools.Finance.TCMB
Usage
1. Service Registration (Program.cs)
Register the client in your Program.cs.
using Easy.Tools.Finance.TCMB;
var builder = WebApplication.CreateBuilder(args);
// 1. Standard Registration
builder.Services.AddTcmbClient();
// 2. OR: Advanced Configuration
builder.Services.AddTcmbClient(options =>
{
options.RetryCount = 3; // Retry 3 times
options.RetryDelaySeconds = 2; // Wait 2 seconds
// options.BaseUrl = "..."; // Optional: Use a proxy URL
});
var app = builder.Build();
2. Fetching Rates (Controller Example)
Inject ITcmbClient into your controllers.
using Easy.Tools.Finance.TCMB;
using Microsoft.AspNetCore.Mvc;
[ApiController]
[Route("[controller]")]
public class CurrencyController : ControllerBase
{
private readonly ITcmbClient _tcmbClient;
public CurrencyController(ITcmbClient tcmbClient)
{
_tcmbClient = tcmbClient;
}
[HttpGet("today")]
public async Task<IActionResult> GetTodayRates(CancellationToken cancellationToken)
{
// Fetch today's rates
var rates = await _tcmbClient.GetTodayRatesAsync(cancellationToken);
// Get USD and EUR
var usd = rates.FirstOrDefault(x => x.Code == "USD");
var eur = rates.FirstOrDefault(x => x.Code == "EUR");
if (usd != null)
Console.WriteLine($"USD Selling: {usd.ForexSelling}");
return Ok(rates);
}
[HttpGet("history/{date}")]
public async Task<IActionResult> GetHistoryRates(DateTime date, CancellationToken cancellationToken)
{
// Fetch historical rates (e.g., 2023-05-15)
// The library automatically formats the URL to: .../202305/15052023.xml
var rates = await _tcmbClient.GetRatesByDateAsync(date, cancellationToken);
return Ok(rates);
}
}
Models
The package returns a list of TcmbCurrency objects.
| Property | Type | Description |
|---|---|---|
Code |
string |
Currency code (e.g., USD, EUR). |
CurrencyName |
string |
English name (e.g., US DOLLAR). |
Name |
string |
Turkish name (e.g., ABD DOLARI). |
Unit |
int |
Unit amount (e.g. 1 or 100). |
ForexBuying |
decimal |
Forex (Döviz) buying rate. |
ForexSelling |
decimal |
Forex (Döviz) selling rate. |
BanknoteBuying |
decimal |
Banknote (Efektif) buying rate. |
BanknoteSelling |
decimal |
Banknote (Efektif) selling rate. |
Contributing
Contributions and suggestions are welcome. Please open an issue or submit a pull request.
License
This project is licensed under the MIT License.
© 2025 Elmin Alirzayev / Easy Code Tools
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 is compatible. net471 was computed. net472 is compatible. net48 is compatible. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.7
- Microsoft.Extensions.Http (>= 10.0.2)
- System.Net.Http (>= 4.3.4)
-
.NETFramework 4.7.2
- Microsoft.Extensions.Http (>= 10.0.2)
- System.Net.Http (>= 4.3.4)
-
.NETFramework 4.8
- Microsoft.Extensions.Http (>= 10.0.2)
- System.Net.Http (>= 4.3.4)
-
.NETStandard 2.0
- Microsoft.Extensions.Http (>= 10.0.2)
-
.NETStandard 2.1
- Microsoft.Extensions.Http (>= 10.0.2)
-
net10.0
- Microsoft.Extensions.Http (>= 10.0.2)
-
net6.0
- Microsoft.Extensions.Http (>= 10.0.2)
-
net7.0
- Microsoft.Extensions.Http (>= 10.0.2)
-
net8.0
- Microsoft.Extensions.Http (>= 10.0.2)
-
net9.0
- Microsoft.Extensions.Http (>= 10.0.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
-