summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTusooa Zhu <tusooa@kazv.moe>2022-03-08 19:12:01 -0500
committerTusooa Zhu <tusooa@kazv.moe>2022-03-08 19:12:01 -0500
commitcf8334dbc153eed7d65febb4ae4fd3c03bb106b2 (patch)
treed3201ebdd3e8937ec37ea043148e3164b3d7938a /lib
parentfcf3c9057ec1c49a0c9a400985c1dde4a5d7e9db (diff)
downloadpleroma-cf8334dbc153eed7d65febb4ae4fd3c03bb106b2.tar.gz
pleroma-cf8334dbc153eed7d65febb4ae4fd3c03bb106b2.zip
Add starts_at, ends_at and all_day parameters
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/announcement.ex16
-rw-r--r--lib/pleroma/web/admin_api/controllers/announcement_controller.ex15
-rw-r--r--lib/pleroma/web/api_spec/operations/admin/announcement_operation.ex5
-rw-r--r--lib/pleroma/web/api_spec/schemas/announcement.ex8
4 files changed, 25 insertions, 19 deletions
diff --git a/lib/pleroma/announcement.ex b/lib/pleroma/announcement.ex
index b3c88b441..85500751e 100644
--- a/lib/pleroma/announcement.ex
+++ b/lib/pleroma/announcement.ex
@@ -24,8 +24,7 @@ defmodule Pleroma.Announcement do
def change(struct, params \\ %{}) do
struct
- |> validate_params()
- |> cast(params, [:data])
+ |> cast(validate_params(params), [:data, :starts_at, :ends_at])
|> validate_required([:data])
end
@@ -39,11 +38,8 @@ defmodule Pleroma.Announcement do
Map.merge(base_struct, params.data)
|> Map.take(["content", "all_day"])
- %{
- data: merged_data,
- starts_at: Map.get(params, "starts_at"),
- ends_at: Map.get(params, "ends_at")
- }
+ params
+ |> Map.merge(%{data: merged_data})
end
def add(params) do
@@ -92,9 +88,9 @@ defmodule Pleroma.Announcement do
base = %{
id: announcement.id,
content: announcement.data["content"],
- starts_at: :null,
- ends_at: :null,
- all_day: false,
+ starts_at: announcement.starts_at,
+ ends_at: announcement.ends_at,
+ all_day: announcement.data["all_day"],
published_at: announcement.inserted_at,
updated_at: announcement.updated_at,
mentions: [],
diff --git a/lib/pleroma/web/admin_api/controllers/announcement_controller.ex b/lib/pleroma/web/admin_api/controllers/announcement_controller.ex
index 803408057..ad94e2642 100644
--- a/lib/pleroma/web/admin_api/controllers/announcement_controller.ex
+++ b/lib/pleroma/web/admin_api/controllers/announcement_controller.ex
@@ -32,12 +32,15 @@ defmodule Pleroma.Web.AdminAPI.AnnouncementController do
end
end
- def create(%{body_params: %{content: content}} = conn, _params) do
- add_params = %{
- data: %{
- "content" => content
- }
- }
+ def create(%{body_params: params} = conn, _params) do
+ data =
+ %{}
+ |> Pleroma.Maps.put_if_present("content", params, &Map.fetch(&1, :content))
+ |> Pleroma.Maps.put_if_present("all_day", params, &Map.fetch(&1, :all_day))
+
+ add_params =
+ params
+ |> Map.merge(%{data: data})
with {:ok, announcement} <- Announcement.add(add_params) do
render(conn, "show.json", announcement: announcement)
diff --git a/lib/pleroma/web/api_spec/operations/admin/announcement_operation.ex b/lib/pleroma/web/api_spec/operations/admin/announcement_operation.ex
index e4212dd06..8179a0e7b 100644
--- a/lib/pleroma/web/api_spec/operations/admin/announcement_operation.ex
+++ b/lib/pleroma/web/api_spec/operations/admin/announcement_operation.ex
@@ -95,7 +95,10 @@ defmodule Pleroma.Web.ApiSpec.Admin.AnnouncementOperation do
type: :object,
required: [:content],
properties: %{
- content: %Schema{type: :string}
+ content: %Schema{type: :string},
+ starts_at: %Schema{type: :string, format: "date-time"},
+ ends_at: %Schema{type: :string, format: "date-time"},
+ all_day: %Schema{type: :boolean}
}
}
end
diff --git a/lib/pleroma/web/api_spec/schemas/announcement.ex b/lib/pleroma/web/api_spec/schemas/announcement.ex
index 433437aac..094fd7c68 100644
--- a/lib/pleroma/web/api_spec/schemas/announcement.ex
+++ b/lib/pleroma/web/api_spec/schemas/announcement.ex
@@ -16,10 +16,14 @@ defmodule Pleroma.Web.ApiSpec.Schemas.Announcement do
id: FlakeID,
content: %Schema{type: :string},
starts_at: %Schema{
- oneOf: [%Schema{type: :null}, %Schema{type: :string, format: "date-time"}]
+ type: :string,
+ format: "date-time",
+ nullable: true
},
ends_at: %Schema{
- oneOf: [%Schema{type: :null}, %Schema{type: :string, format: "date-time"}]
+ type: :string,
+ format: "date-time",
+ nullable: true
},
all_day: %Schema{type: :boolean},
published_at: %Schema{type: :string, format: "date-time"},