forked from potsda.mn/mobilizon
feat(background): add a job to refresh participant stats
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
parent
6df16ef114
commit
11e42d6601
|
@ -324,6 +324,7 @@ config :mobilizon, Oban,
|
||||||
{"@hourly", Mobilizon.Service.Workers.ExportCleanerWorker, queue: :background},
|
{"@hourly", Mobilizon.Service.Workers.ExportCleanerWorker, queue: :background},
|
||||||
{"@hourly", Mobilizon.Service.Workers.SendActivityRecapWorker, queue: :notifications},
|
{"@hourly", Mobilizon.Service.Workers.SendActivityRecapWorker, queue: :notifications},
|
||||||
{"@daily", Mobilizon.Service.Workers.CleanOldActivityWorker, queue: :background},
|
{"@daily", Mobilizon.Service.Workers.CleanOldActivityWorker, queue: :background},
|
||||||
|
{"@daily", Mobilizon.Service.Workers.RefreshParticipantStats, queue: :background},
|
||||||
{"@hourly", Mobilizon.Service.Workers.CleanApplicationData,
|
{"@hourly", Mobilizon.Service.Workers.CleanApplicationData,
|
||||||
queue: :background, args: %{type: :application_token}},
|
queue: :background, args: %{type: :application_token}},
|
||||||
{"@hourly", Mobilizon.Service.Workers.CleanApplicationData,
|
{"@hourly", Mobilizon.Service.Workers.CleanApplicationData,
|
||||||
|
|
61
lib/service/workers/refresh_participant_stats.ex
Normal file
61
lib/service/workers/refresh_participant_stats.ex
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
defmodule Mobilizon.Service.Workers.RefreshParticipantStats do
|
||||||
|
@moduledoc """
|
||||||
|
Worker to refresh the participant event stats based on participants data
|
||||||
|
"""
|
||||||
|
|
||||||
|
use Oban.Worker, unique: [period: :infinity, keys: [:event_uuid, :action]]
|
||||||
|
|
||||||
|
alias Mobilizon.Events
|
||||||
|
alias Mobilizon.Events.{Event, Participant}
|
||||||
|
alias Mobilizon.Storage.Page
|
||||||
|
alias Oban.Job
|
||||||
|
require Logger
|
||||||
|
|
||||||
|
@impl Oban.Worker
|
||||||
|
@spec perform(Oban.Job.t()) :: :ok
|
||||||
|
def perform(%Job{}) do
|
||||||
|
refresh_participant_stats()
|
||||||
|
end
|
||||||
|
|
||||||
|
def refresh_participant_stats do
|
||||||
|
Logger.info("Launching RefreshParticipantStats job")
|
||||||
|
%Page{elements: future_events} = Events.list_events(1, 100_000_000)
|
||||||
|
|
||||||
|
updated_events_count =
|
||||||
|
Enum.reduce(future_events, 0, fn %Event{} = event, updated_events_count ->
|
||||||
|
participants = Events.list_all_participants_for_event(event.id)
|
||||||
|
|
||||||
|
participant_stats =
|
||||||
|
Enum.reduce(
|
||||||
|
participants,
|
||||||
|
%{
|
||||||
|
not_approved: 0,
|
||||||
|
not_confirmed: 0,
|
||||||
|
rejected: 0,
|
||||||
|
participant: 0,
|
||||||
|
moderator: 0,
|
||||||
|
administrator: 0,
|
||||||
|
creator: 0
|
||||||
|
},
|
||||||
|
fn %Participant{role: role}, acc ->
|
||||||
|
Map.update(acc, role, 1, &(&1 + 1))
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
if participant_stats != Map.from_struct(event.participant_stats) do
|
||||||
|
Logger.debug("Uupdating event #{event.id} because of wrong participant_stats")
|
||||||
|
|
||||||
|
Events.update_event(event, %{
|
||||||
|
participant_stats: participant_stats
|
||||||
|
})
|
||||||
|
|
||||||
|
updated_events_count + 1
|
||||||
|
else
|
||||||
|
Logger.debug("Skipped updating event #{event.id}")
|
||||||
|
updated_events_count
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
Logger.info("Updated #{updated_events_count} events on #{length(future_events)}")
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue