Skip to content

Commit

Permalink
Add params, and updated supporting code (#17)
Browse files Browse the repository at this point in the history
* Add params, and updated supporting code

* Add IDatabricksJobhelper injection

* Fixed nullable property which was not nullable

also add another missing dependency

* Update SettlementReportModuleExtensions.cs

* Update Program.cs

* Update SettlementReportsController.cs

* Actually return reports

* Use instant in params

* remove string converter

* Update Program.cs

* Update DatabricksJobsHelper.cs
  • Loading branch information
FirestarJes authored Sep 13, 2024
1 parent 437ffbe commit 3d1ae7f
Show file tree
Hide file tree
Showing 17 changed files with 93 additions and 49 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,5 @@ public sealed record RequestSettlementReportCommand(
Guid UserId,
Guid ActorId,
bool IsFas,
string? ChargeOwnerId);
string? ChargeOwnerId,
MarketRole MarketRole);
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,15 @@ public RequestSettlementReportHandler(

public async Task<JobRunId> HandleAsync(RequestSettlementReportCommand request)
{
var runId = await _jobHelper.RunSettlementReportsJobAsync(request.RequestDto).ConfigureAwait(false);
var reportId = new SettlementReportRequestId(Guid.NewGuid().ToString());
var runId = await _jobHelper.RunSettlementReportsJobAsync(request.RequestDto, request.MarketRole, reportId).ConfigureAwait(false);
await _settlementReportInitializeHandler
.InitializeFromJobAsync(
request.UserId,
request.ActorId,
request.IsFas,
runId,
reportId,
request.RequestDto)
.ConfigureAwait(false);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ private static RequestedSettlementReportDto Map(SettlementReport report)
new Dictionary<string, CalculationId?>();

return new RequestedSettlementReportDto(
report.RequestId is not null ? new SettlementReportRequestId(report.RequestId) : null,
new SettlementReportRequestId(report.RequestId),
report.CalculationType,
report.PeriodStart.ToDateTimeOffset(),
report.PeriodEnd.ToDateTimeOffset(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ public sealed class SettlementReport
{
public int Id { get; init; }

public string? RequestId { get; init; }
public string RequestId { get; init; } = null!;

public Guid UserId { get; init; }

Expand Down Expand Up @@ -88,8 +88,10 @@ public SettlementReport(
Guid actorId,
bool hideReport,
JobRunId jobRunId,
SettlementReportRequestId requestId,
SettlementReportRequestDto request)
{
RequestId = requestId.Id;
JobId = jobRunId.Id;
UserId = userId;
ActorId = actorId;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,9 +38,15 @@ public Task InitializeAsync(
return _repository.AddOrUpdateAsync(settlementReport);
}

public Task InitializeFromJobAsync(Guid userId, Guid actorId, bool hideReport, JobRunId jobId, SettlementReportRequestDto request)
public Task InitializeFromJobAsync(
Guid userId,
Guid actorId,
bool hideReport,
JobRunId jobId,
SettlementReportRequestId requestId,
SettlementReportRequestDto request)
{
var settlementReport = new SettlementReport(SystemClock.Instance, userId, actorId, hideReport, new SettlementReportRequestId(jobId.ToString()), request);
var settlementReport = new SettlementReport(SystemClock.Instance, userId, actorId, hideReport, jobId, requestId, request);
return _repository.AddOrUpdateAsync(settlementReport);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -67,24 +67,4 @@ public static IServiceCollection AddSettlementReportBlobStorage(this IServiceCol

return services;
}

public static IServiceCollection AddSettlementReportBlobStorageForJobs(this IServiceCollection services)
{
services
.AddOptions<SettlementReportStorageOptions>()
.BindConfiguration(SettlementReportStorageOptions.SectionName)
.ValidateDataAnnotations();

services.AddScoped<ISettlementReportJobsFileRepository, SettlementReportJobsFileBlobStorage>(serviceProvider =>
{
var blobSettings = serviceProvider.GetRequiredService<IOptions<SettlementReportStorageOptions>>().Value;

var blobContainerUri = new Uri(blobSettings.StorageAccountUri, blobSettings.StorageContainerName);
var blobContainerClient = new BlobContainerClient(blobContainerUri, new DefaultAzureCredential());

return new SettlementReportJobsFileBlobStorage(blobContainerClient);
});

return services;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
using Energinet.DataHub.SettlementReport.Interfaces.Models;
using Energinet.DataHub.SettlementReport.Interfaces.SettlementReports_v2.Models;
using Microsoft.Azure.Databricks.Client.Models;
using NodaTime.Extensions;

namespace Energinet.DataHub.SettlementReport.Infrastructure.Helpers;

Expand All @@ -31,10 +32,13 @@ public DatabricksJobsHelper(IJobsApiClient jobsApiClient)
_jobsApiClient = jobsApiClient;
}

public async Task<JobRunId> RunSettlementReportsJobAsync(SettlementReportRequestDto request)
public async Task<JobRunId> RunSettlementReportsJobAsync(
SettlementReportRequestDto request,
MarketRole marketRole,
SettlementReportRequestId reportId)
{
var job = await GetSettlementReportsJobAsync(GetJobName(request.Filter.CalculationType)).ConfigureAwait(false);
return new JobRunId(await _jobsApiClient.Jobs.RunNow(job.JobId, CreateParameters(request)).ConfigureAwait(false));
return new JobRunId(await _jobsApiClient.Jobs.RunNow(job.JobId, CreateParameters(request, marketRole, reportId)).ConfigureAwait(false));
}

public async Task<JobRunStatus> GetSettlementReportsJobStatusAsync(long runId)
Expand Down Expand Up @@ -67,21 +71,49 @@ private async Task<Job> GetSettlementReportsJobAsync(string jobName)
return await _jobsApiClient.Jobs.Get(settlementJob.JobId).ConfigureAwait(false);
}

private RunParameters CreateParameters(SettlementReportRequestDto request)
private RunParameters CreateParameters(SettlementReportRequestDto request, MarketRole marketRole, SettlementReportRequestId reportId)
{
var gridAreas = string.Join(", ", request.Filter.GridAreas.Select(c => c.Key));
var gridAreas = $"{{{string.Join(", ", request.Filter.GridAreas.Select(c => $"{c.Key}: {c.Value}"))}}}";

var jobParameters = new List<string>
{
$"--grid-areas=[{gridAreas}]",
$"--period-start-datetime={request.Filter.PeriodStart}",
$"--period-end-datetime={request.Filter.PeriodEnd}",
$"--report-id={reportId}",
$"--calculation-type={CalculationTypeMapper.ToDeltaTableValue(request.Filter.CalculationType)}",
$"--calculation-id-by-grid-area={gridAreas}",
$"--period-start={request.Filter.PeriodStart.ToInstant()}",
$"--period-end={request.Filter.PeriodEnd.ToInstant()}",
$"--market-role={MapMarketRole(marketRole)}",
};
if (request.Filter.EnergySupplier != null)
{
jobParameters.Add($"--energy-supplier-id={request.Filter.EnergySupplier}");
}

if (request.SplitReportPerGridArea)
{
jobParameters.Add("--split-report-by-grid-area");
}

if (request.PreventLargeTextFiles)
{
jobParameters.Add("--prevent-large-text-files");
}

return RunParameters.CreatePythonParams(jobParameters);
}

private static string MapMarketRole(MarketRole marketRole)
{
return marketRole switch
{
MarketRole.EnergySupplier => "energy_supplier",
MarketRole.DataHubAdministrator => "datahub_administrator",
MarketRole.GridAccessProvider => "grid_access_provider",
MarketRole.SystemOperator => "system_operator",
_ => throw new ArgumentOutOfRangeException(nameof(marketRole), marketRole, $"Market role \"{marketRole}\" not supported in report generation"),
};
}

private static JobRunStatus ConvertJobStatus(Run jobRun)
{
if (jobRun.State == null)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,16 +49,20 @@ public async Task RemoveExpiredAsync(IList<Application.SettlementReports_v2.Sett

if (settlementReport.BlobFileName != null)
{
if (settlementReport.RequestId is not null)
if (settlementReport.JobId is not null)
{
await _settlementReportFileRepository
.DeleteAsync(new SettlementReportRequestId(settlementReport.RequestId), settlementReport.BlobFileName)
await _settlementReportJobFileRepository
.DeleteAsync(
new JobRunId(settlementReport.JobId.GetValueOrDefault()),
settlementReport.BlobFileName)
.ConfigureAwait(false);
}
else if (settlementReport.JobId is not null)
else
{
await _settlementReportJobFileRepository
.DeleteAsync(new JobRunId(settlementReport.JobId.GetValueOrDefault()), settlementReport.BlobFileName)
await _settlementReportFileRepository
.DeleteAsync(
new SettlementReportRequestId(settlementReport.RequestId),
settlementReport.BlobFileName)
.ConfigureAwait(false);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -267,13 +267,15 @@ public async Task GetAsync_HiddenReport_ReturnsRequestsForJobs()
expectedRequest.ActorId,
true,
new JobRunId(Random.Shared.NextInt64()),
new SettlementReportRequestId(Guid.NewGuid().ToString()),
new SettlementReportRequestDto(false, false, false, false, requestFilterDto)));
await PrepareNewRequestAsync(requestFilterDto => new SettlementReport.Application.SettlementReports_v2.SettlementReport(
SystemClock.Instance,
Guid.NewGuid(),
expectedRequest.ActorId,
true,
new JobRunId(Random.Shared.NextInt64()),
new SettlementReportRequestId(Guid.NewGuid().ToString()),
new SettlementReportRequestDto(false, false, false, false, requestFilterDto)));

await using var context = _databaseManager.CreateDbContext();
Expand Down Expand Up @@ -348,6 +350,7 @@ public async Task GetAsync_HiddenReport_ReturnsRequestsForJobs()
Guid.NewGuid(),
false,
new JobRunId(Random.Shared.NextInt64()),
new SettlementReportRequestId(Guid.NewGuid().ToString()),
new SettlementReportRequestDto(false, false, false, false, requestFilterDto));

if (createReport != null)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,10 @@ namespace Energinet.DataHub.SettlementReport.Interfaces.Helpers;

public interface IDatabricksJobsHelper
{
Task<JobRunId> RunSettlementReportsJobAsync(SettlementReportRequestDto request);
Task<JobRunId> RunSettlementReportsJobAsync(
SettlementReportRequestDto request,
MarketRole marketRole,
SettlementReportRequestId reportId);

Task<JobRunStatus> GetSettlementReportsJobStatusAsync(long runId);
}
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,7 @@
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\Common.Infrastructure\Common.Infrastructure.csproj" />
</ItemGroup>
</Project>
Original file line number Diff line number Diff line change
Expand Up @@ -30,5 +30,6 @@ Task InitializeFromJobAsync(
Guid actorId,
bool hideReport,
JobRunId jobId,
SettlementReportRequestId requestId,
SettlementReportRequestDto request);
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
namespace Energinet.DataHub.SettlementReport.Interfaces.SettlementReports_v2.Models;

public sealed record RequestedSettlementReportDto(
SettlementReportRequestId? RequestId,
SettlementReportRequestId RequestId,
CalculationType CalculationType,
DateTimeOffset PeriodStart,
DateTimeOffset PeriodEnd,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,10 +51,10 @@ public async Task Handle_ValidRequest_ReturnsJobId()
var jobHelperMock = new Mock<IDatabricksJobsHelper>();
var jobRunId = new JobRunId(Random.Shared.NextInt64());
jobHelperMock
.Setup(x => x.RunSettlementReportsJobAsync(It.IsAny<SettlementReportRequestDto>()))
.Setup(x => x.RunSettlementReportsJobAsync(It.IsAny<SettlementReportRequestDto>(), It.IsAny<MarketRole>(), It.IsAny<SettlementReportRequestId>()))
.ReturnsAsync(jobRunId);

var command = new RequestSettlementReportCommand(request, Guid.NewGuid(), Guid.NewGuid(), true, null);
var command = new RequestSettlementReportCommand(request, Guid.NewGuid(), Guid.NewGuid(), true, null, MarketRole.EnergySupplier);
var handler = new RequestSettlementReportHandler(jobHelperMock.Object, initializerMock.Object);

// Act
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,8 @@ public async Task<ActionResult<long>> RequestSettlementReport([FromBody] Settlem
_userContext.CurrentUser.UserId,
_userContext.CurrentUser.Actor.ActorId,
_userContext.CurrentUser.MultiTenancy,
chargeOwnerId);
chargeOwnerId,
marketRole);

var result = await _requestSettlementReportJobHandler.HandleAsync(requestCommand).ConfigureAwait(false);

Expand All @@ -97,11 +98,11 @@ public async Task<ActionResult<long>> RequestSettlementReport([FromBody] Settlem

[HttpGet]
[Route("list")]
[AllowAnonymous]
[Authorize]
public async Task<IEnumerable<RequestedSettlementReportDto>> ListSettlementReports()
{
if (_userContext.CurrentUser.MultiTenancy)
await _listSettlementReportJobsHandler.HandleAsync().ConfigureAwait(false);
return await _listSettlementReportJobsHandler.HandleAsync().ConfigureAwait(false);

return await _listSettlementReportJobsHandler.HandleAsync(_userContext.CurrentUser.Actor.ActorId).ConfigureAwait(false);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,11 @@
using Energinet.DataHub.SettlementReport.Common.Infrastructure.Extensions.Options;
using Energinet.DataHub.SettlementReport.Common.Infrastructure.HealthChecks;
using Energinet.DataHub.SettlementReport.Infrastructure.Extensions.DependencyInjection;
using Energinet.DataHub.SettlementReport.Infrastructure.Helpers;
using Energinet.DataHub.SettlementReport.Infrastructure.Persistence;
using Energinet.DataHub.SettlementReport.Infrastructure.Persistence.SettlementReportRequest;
using Energinet.DataHub.SettlementReport.Infrastructure.SettlementReports_v2;
using Energinet.DataHub.SettlementReport.Interfaces.Helpers;
using Energinet.DataHub.SettlementReport.Interfaces.SettlementReports_v2;
using Microsoft.EntityFrameworkCore;

Expand All @@ -38,6 +40,10 @@ public static IServiceCollection AddSettlementReportApiModule(this IServiceColle
services.AddScoped<ISettlementReportRepository, SettlementReportRepository>();
services.AddScoped<IGetSettlementReportsHandler, GetSettlementReportsHandler>();
services.AddScoped<IRemoveExpiredSettlementReports, RemoveExpiredSettlementReports>();
services.AddScoped<IDatabricksJobsHelper, DatabricksJobsHelper>();
services.AddScoped<ISettlementReportInitializeHandler, SettlementReportInitializeHandler>();
services.AddScoped<IListSettlementReportJobsHandler, ListSettlementReportJobsHandler>();
services.AddScoped<IRequestSettlementReportJobHandler, RequestSettlementReportHandler>();
services.AddSettlementReportBlobStorage();

// Database Health check
Expand Down
6 changes: 3 additions & 3 deletions source/settlement-report/SettlementReports.WebAPI/Program.cs
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,13 @@
using System.Reflection;
using System.Text.Json.Serialization;
using Asp.Versioning;
using Energinet.DataHub.Core.App.Common.Extensions.DependencyInjection;
using Energinet.DataHub.Core.App.WebApp.Extensions.Builder;
using Energinet.DataHub.Core.App.WebApp.Extensions.DependencyInjection;
using Energinet.DataHub.Core.Databricks.Jobs.Extensions.DependencyInjection;
using Energinet.DataHub.Core.Logging.LoggingMiddleware;
using Energinet.DataHub.SettlementReport.Common.Infrastructure.Security;
using Energinet.DataHub.SettlementReport.Common.Infrastructure.Telemetry;
using Energinet.DataHub.SettlementReport.Infrastructure.Extensions.DependencyInjection;
using SettlementReports.WebAPI.Extensions.DependencyInjection;

const string subsystemName = TelemetryConstants.SubsystemName;
Expand All @@ -33,8 +33,7 @@
builder.Services.AddHealthChecksForWebApp();

builder.Services
.AddControllers()
.AddJsonOptions(options => options.JsonSerializerOptions.Converters.Add(new JsonStringEnumConverter()));
.AddControllers();

builder.Services
.AddApiVersioningForWebApp(new ApiVersion(1, 0))
Expand All @@ -43,6 +42,7 @@
.AddUserAuthenticationForWebApp<FrontendUser, FrontendUserProvider>()
.AddDatabricksJobs(builder.Configuration)
.AddSettlementReportApiModule(builder.Configuration)
.AddNodaTimeForApplication()
.AddPermissionAuthorizationForWebApp();

var app = builder.Build();
Expand Down

0 comments on commit 3d1ae7f

Please sign in to comment.