aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/object.ex
diff options
context:
space:
mode:
authorIvan Tashkinov <ivantashkinov@gmail.com>2020-12-22 22:04:33 +0300
committerIvan Tashkinov <ivantashkinov@gmail.com>2020-12-22 22:04:33 +0300
commite369b1306b2f8b9732c21333b9957f7e4e408f90 (patch)
tree78b7a949f3af1ca1313bb58404646b11f7043473 /lib/pleroma/object.ex
parentee221277b05d2f682c340c1e1b81fbce4931735a (diff)
downloadpleroma-e369b1306b2f8b9732c21333b9957f7e4e408f90.tar.gz
Added Hashtag entity and objects-hashtags association with auto-sync with `data.tag` on Object update.
Diffstat (limited to 'lib/pleroma/object.ex')
-rw-r--r--lib/pleroma/object.ex37
1 files changed, 27 insertions, 10 deletions
diff --git a/lib/pleroma/object.ex b/lib/pleroma/object.ex
index 2088c7656..357a3b504 100644
--- a/lib/pleroma/object.ex
+++ b/lib/pleroma/object.ex
@@ -10,6 +10,7 @@ defmodule Pleroma.Object do
alias Pleroma.Activity
alias Pleroma.Config
+ alias Pleroma.Hashtag
alias Pleroma.Object
alias Pleroma.Object.Fetcher
alias Pleroma.ObjectTombstone
@@ -26,6 +27,8 @@ defmodule Pleroma.Object do
schema "objects" do
field(:data, :map)
+ many_to_many(:hashtags, Hashtag, join_through: "hashtags_objects", on_replace: :delete)
+
timestamps()
end
@@ -53,17 +56,31 @@ defmodule Pleroma.Object do
end
def change(struct, params \\ %{}) do
- changeset =
- struct
- |> cast(params, [:data])
- |> validate_required([:data])
- |> unique_constraint(:ap_id, name: :objects_unique_apid_index)
-
- if hashtags_changed?(struct, get_change(changeset, :data)) do
- # TODO: modify assoc once it's introduced
- changeset
+ struct
+ |> cast(params, [:data])
+ |> validate_required([:data])
+ |> unique_constraint(:ap_id, name: :objects_unique_apid_index)
+ |> maybe_handle_hashtags_change(struct)
+ end
+
+ defp maybe_handle_hashtags_change(changeset, struct) do
+ with data_hashtags_change = get_change(changeset, :data),
+ true <- hashtags_changed?(struct, data_hashtags_change),
+ {:ok, hashtag_records} <-
+ data_hashtags_change
+ |> object_data_hashtags()
+ |> Hashtag.get_or_create_by_names() do
+ put_assoc(changeset, :hashtags, hashtag_records)
else
- changeset
+ false ->
+ changeset
+
+ {:error, hashtag_changeset} ->
+ failed_hashtag = get_field(hashtag_changeset, :name)
+
+ validate_change(changeset, :data, fn _, _ ->
+ [data: "error referencing hashtag: #{failed_hashtag}"]
+ end)
end
end