From ff5ddd040e9866db59be714219298f651e230a7a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?marcin=20miko=C5=82ajczak?= Date: Sun, 21 Aug 2022 23:23:35 +0200 Subject: [PATCH] Validate event datetime MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: marcin mikołajczak --- lib/pleroma/web/common_api/activity_draft.ex | 34 ++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/lib/pleroma/web/common_api/activity_draft.ex b/lib/pleroma/web/common_api/activity_draft.ex index dd31815909..8ee6a2706c 100644 --- a/lib/pleroma/web/common_api/activity_draft.ex +++ b/lib/pleroma/web/common_api/activity_draft.ex @@ -102,6 +102,7 @@ def event(user, params) do |> to_and_cc() |> context() |> event_object() + |> with_valid(&event_date/1) |> with_valid(&changes/1) |> validate() end @@ -117,8 +118,8 @@ defp event_object(draft) do |> Map.put("cc", draft.cc) |> Map.put("content", draft.content_html) |> Map.put("actor", draft.user.ap_id) - |> Map.put("startTime", draft.params[:start_time]) - |> Map.put("endTime", draft.params[:end_time]) + # |> Map.put("startTime", draft.params[:start_time]) + # |> Map.put("endTime", draft.params[:end_time]) |> Map.put("joinMode", draft.params[:join_mode]) |> Map.put("tag", Keyword.values(draft.tags) |> Enum.uniq()) |> Map.put("emoji", emoji) @@ -326,6 +327,35 @@ defp changes(draft) do %__MODULE__{draft | changes: changes} end + defp event_date(draft) do + case draft.params[:start_time] do + %DateTime{} = start_time -> + case draft.params[:end_time] do + %DateTime{} = end_time -> + if DateTime.compare(end_time, start_time) == :lt do + add_error(draft, dgettext("errors", "Event can't end before its start")) + else + object = + draft.object + |> Map.put("startTime", start_time) + |> Map.put("endTime", end_time) + + %__MODULE__{draft | object: object} + end + + _ -> + object = + draft.object + |> Map.put("startTime", start_time) + + %__MODULE__{draft | object: object} + end + + _ -> + add_error(draft, dgettext("errors", "Start date is required")) + end + end + defp with_valid(%{valid?: true} = draft, func), do: func.(draft) defp with_valid(draft, _func), do: draft