public Task <List <InsolationVm> > Handle(GetInsolationQuery request, CancellationToken cancellationToken)
        {
            var currentDate = _dateTimeProvider.GetUtcNow();

            request.WithDefaultValues(currentDate.AddDays(-2), currentDate);
            int granulation = (int)(request.Granulation ?? default);

            Debug.Assert(request.From != null, "request.From != null");
            var fromDate = request.From.Value;

            return(_applicationDbContext.WeatherStationInsolationParameters
                   .AsNoTracking()
                   .Where(x => x.MeasurementStartTime >= request.From && x.MeasurementEndTime <= request.To)
                   .Select(x => new
            {
                TimestampGroup = granulation == (int)DateRangeGranulation.Year
                        ? EF.Functions.DateDiffYear(fromDate, x.MeasurementEndTime)
                        : granulation == (int)DateRangeGranulation.Month
                            ? EF.Functions.DateDiffMonth(fromDate, x.MeasurementEndTime)
                            : EF.Functions.DateDiffSecond(fromDate, x.MeasurementEndTime) / granulation,
                x.LightLevelInLux,
            })
                   .GroupBy(x => x.TimestampGroup)
                   .OrderBy(x => x.Key)
                   .Select(g => new InsolationVm()
            {
                Timestamp = DateTime.SpecifyKind(
                    granulation == (int)DateRangeGranulation.Year
                            ? fromDate.AddYears(g.Key)
                            : granulation == (int)DateRangeGranulation.Month
                                ? fromDate.AddMonths(g.Key)
                                : fromDate.AddSeconds(g.Key * granulation),
                    DateTimeKind.Utc),
                LightLevel = Math.Round(g.Average(x => x.LightLevelInLux), 2),
                MaxLightLevel = Math.Round(g.Max(x => x.LightLevelInLux), 2),
                MinLightLevel = Math.Round(g.Min(x => x.LightLevelInLux), 2)
            })
                   .ToListAsync(cancellationToken));
        }
Ejemplo n.º 2
0
 public Task <IEnumerable <InsolationVm> > GetInsolation(GetInsolationQuery query)
 {
     return(_apiClient.Get <GetInsolationQuery, IEnumerable <InsolationVm> >("GreenhouseData/insolation", query));
 }
 public async Task <IActionResult> GetInsolation([FromQuery] GetInsolationQuery query)
 {
     return(Ok(await _mediator.Send(query)));
 }