PlanTempusApp/Core/Database/SqlOperations.cs

58 lines
1.7 KiB
C#
Raw Normal View History

2025-03-04 23:54:55 +01:00
using System.Data;
using Microsoft.ApplicationInsights;
2025-03-03 17:40:16 +01:00
using Microsoft.ApplicationInsights.DataContracts;
2025-03-10 15:56:22 +01:00
using PlanTempus.Core.Database.ConnectionFactory;
2025-03-03 17:40:16 +01:00
2025-03-10 15:56:22 +01:00
namespace PlanTempus.Core.Database;
2025-03-03 17:40:16 +01:00
2025-03-04 23:54:55 +01:00
public class SqlOperations : IDatabaseOperations
{
private readonly IDbConnectionFactory _connectionFactory;
private readonly TelemetryClient _telemetryClient;
public SqlOperations(IDbConnectionFactory connectionFactory, TelemetryClient telemetryClient)
{
_connectionFactory = connectionFactory;
_telemetryClient = telemetryClient;
}
public DatabaseScope CreateScope(string operationName)
{
var connection = _connectionFactory.Create();
connection.Open();
2025-03-04 23:54:55 +01:00
var operation = _telemetryClient.StartOperation<DependencyTelemetry>(operationName);
operation.Telemetry.Type = "SQL";
operation.Telemetry.Target = "PostgreSQL";
return new DatabaseScope(connection, operation);
}
public async Task<T> ExecuteAsync<T>(Func<IDbConnection, Task<T>> operation, string operationName)
{
using var scope = CreateScope(operationName);
try
{
var result = await operation(scope.Connection);
return result;
}
catch (Exception ex)
{
scope.Error(ex);
throw;
}
}
public async Task ExecuteAsync(Func<IDbConnection, Task> operation, string operationName)
{
using var scope = CreateScope(operationName);
try
{
await operation(scope.Connection);
}
catch (Exception ex)
{
scope.Error(ex);
throw;
}
}
}