mirror of
https://github.com/plausible/analytics.git
synced 2025-01-06 09:50:56 +03:00
d2270f3c35
* use more convenient testing functions * do not display + sign with 0% change in emails * Rename module/file/function names before, `weekly_report` was also used for monthly reports and that was a bit confusing to read in code. * Refactor send_email_report.ex This commit improves readability by refactoring the code into smaller functions and reducing the number of arguments given to functions. But more importantly, it stops making duplicate stats queries for every email recipient by moving the queries out of the for loop. * Refactor: move querying logic out of the worker module and merge all stats information under a single `stats` assign.
87 lines
2.6 KiB
Elixir
87 lines
2.6 KiB
Elixir
defmodule Plausible.Workers.SendEmailReport do
|
|
use Plausible.Repo
|
|
use Oban.Worker, queue: :send_email_reports, max_attempts: 1
|
|
alias Plausible.Stats.Query
|
|
|
|
@impl Oban.Worker
|
|
def perform(%Oban.Job{args: %{"interval" => "weekly", "site_id" => site_id}}) do
|
|
site = Repo.get(Plausible.Site, site_id) |> Repo.preload(:weekly_report)
|
|
|
|
if site do
|
|
%{site: site}
|
|
|> Map.put(:type, :weekly)
|
|
|> Map.put(:name, "Weekly")
|
|
|> put_last_week_query()
|
|
|> put_stats()
|
|
|> send_report_for_all(site.weekly_report.recipients)
|
|
else
|
|
:discard
|
|
end
|
|
end
|
|
|
|
@impl Oban.Worker
|
|
def perform(%Oban.Job{args: %{"interval" => "monthly", "site_id" => site_id}}) do
|
|
site = Repo.get(Plausible.Site, site_id) |> Repo.preload(:monthly_report)
|
|
|
|
if site do
|
|
%{site: site}
|
|
|> Map.put(:type, :monthly)
|
|
|> put_last_month_query()
|
|
|> put_monthly_report_name()
|
|
|> put_stats()
|
|
|> send_report_for_all(site.monthly_report.recipients)
|
|
else
|
|
:discard
|
|
end
|
|
end
|
|
|
|
defp send_report_for_all(_assigns, [] = _recipients), do: :ok
|
|
|
|
defp send_report_for_all(assigns, [email | rest]) do
|
|
unsubscribe_link =
|
|
PlausibleWeb.Endpoint.url() <>
|
|
"/sites/#{URI.encode_www_form(assigns.site.domain)}/#{assigns.type}-report/unsubscribe?email=#{email}"
|
|
|
|
user = Plausible.Auth.find_user_by(email: email)
|
|
login_link = user && Plausible.Sites.is_member?(user.id, assigns.site)
|
|
|
|
template_assigns =
|
|
assigns
|
|
|> Map.put(:unsubscribe_link, unsubscribe_link)
|
|
|> Map.put(:login_link, login_link)
|
|
|
|
PlausibleWeb.Email.stats_report(email, template_assigns)
|
|
|> Plausible.Mailer.send()
|
|
|
|
send_report_for_all(assigns, rest)
|
|
end
|
|
|
|
defp put_last_month_query(%{site: site} = assigns) do
|
|
last_month =
|
|
Timex.now(site.timezone)
|
|
|> Timex.shift(months: -1)
|
|
|> Timex.beginning_of_month()
|
|
|> Timex.format!("{ISOdate}")
|
|
|
|
query = Query.from(site, %{"period" => "month", "date" => last_month})
|
|
|
|
Map.put(assigns, :query, query)
|
|
end
|
|
|
|
defp put_last_week_query(%{site: site} = assigns) do
|
|
today = Timex.now(site.timezone) |> DateTime.to_date()
|
|
date = Timex.shift(today, weeks: -1) |> Timex.end_of_week() |> Date.to_iso8601()
|
|
query = Query.from(site, %{"period" => "7d", "date" => date})
|
|
|
|
Map.put(assigns, :query, query)
|
|
end
|
|
|
|
defp put_monthly_report_name(%{query: query} = assigns) do
|
|
Map.put(assigns, :name, Timex.format!(query.date_range.first, "{Mfull}"))
|
|
end
|
|
|
|
defp put_stats(%{site: site, query: query} = assigns) do
|
|
Map.put(assigns, :stats, Plausible.Stats.EmailReport.get(site, query))
|
|
end
|
|
end
|