From a7bc48d61dc1e65e8dc6de7aced935bc31c1fc04 Mon Sep 17 00:00:00 2001 From: Matthias Wirtz Date: Sat, 28 Sep 2024 13:04:26 +0200 Subject: [PATCH] limit positions to set elevation for to last 10 days --- lib/teslamate/log.ex | 32 ++++++++++++++++++-------------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/lib/teslamate/log.ex b/lib/teslamate/log.ex index 8875f0a11d5..2d1f9c667c0 100644 --- a/lib/teslamate/log.ex +++ b/lib/teslamate/log.ex @@ -172,26 +172,30 @@ defmodule TeslaMate.Log do def get_positions_without_elevation(min_id \\ 0, opts \\ []) do limit = Keyword.get(opts, :limit, 100) + now = DateTime.utc_now() non_streamed_drives = Repo.all( - from d in subquery( - from p in Position, - select: %{ - drive_id: p.drive_id, - streamed_count: - count() - |> filter(not is_nil(p.odometer) and is_nil(p.ideal_battery_range_km)) - }, - where: not is_nil(p.drive_id), - group_by: p.drive_id - ), - select: d.drive_id, - where: d.streamed_count == 0 + from p in Position, + select: %{ + drive_id: p.drive_id + }, + join: d in assoc(p, :drive), + where: + p.date > ^DateTime.add(now, -10, :day) and + d.start_date > ^DateTime.add(now, -10, :day), + having: + count() + |> filter(not is_nil(p.odometer) and is_nil(p.ideal_battery_range_km)) > 0, + group_by: p.drive_id ) Position - |> where([p], p.id > ^min_id and is_nil(p.elevation) and p.drive_id in ^non_streamed_drives) + |> where( + [p], + p.id > ^min_id and is_nil(p.elevation) and p.drive_id in ^non_streamed_drives and + p.date > ^DateTime.add(now, -10, :day) + ) |> order_by(asc: :id) |> limit(^limit) |> Repo.all()