projects
/
akkoma
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
HTML-sanitize usernames before emojifying.
[akkoma]
/
lib
/
pleroma
/
object.ex
diff --git
a/lib/pleroma/object.ex
b/lib/pleroma/object.ex
index 5b51d6be340170e649c55b7e8c8d06083c9464a2..1bcff5a7b092f5dbc1db4a23192f2d98b4e5cf99 100644
(file)
--- a/
lib/pleroma/object.ex
+++ b/
lib/pleroma/object.ex
@@
-4,35
+4,42
@@
defmodule Pleroma.Object do
import Ecto.{Query, Changeset}
schema "objects" do
import Ecto.{Query, Changeset}
schema "objects" do
- field
:data, :map
+ field
(:data, :map)
timestamps()
end
def create(data) do
Object.change(%Object{}, %{data: data})
timestamps()
end
def create(data) do
Object.change(%Object{}, %{data: data})
- |> Repo.insert
+ |> Repo.insert
()
end
def change(struct, params \\ %{}) do
end
def change(struct, params \\ %{}) do
-
changeset =
struct
+ struct
|> cast(params, [:data])
|> validate_required([:data])
|> unique_constraint(:ap_id, name: :objects_unique_apid_index)
end
|> cast(params, [:data])
|> validate_required([:data])
|> unique_constraint(:ap_id, name: :objects_unique_apid_index)
end
+ def get_by_ap_id(nil), do: nil
+
def get_by_ap_id(ap_id) do
def get_by_ap_id(ap_id) do
- Repo.one(from object in Object,
- where: fragment("? @> ?", object.data, ^%{id: ap_id}))
+ Repo.one(from(object in Object, where: fragment("(?)->>'id' = ?", object.data, ^ap_id)))
end
end
+ def normalize(obj) when is_map(obj), do: Object.get_by_ap_id(obj["id"])
+ def normalize(ap_id) when is_binary(ap_id), do: Object.get_by_ap_id(ap_id)
+ def normalize(_), do: nil
+
def get_cached_by_ap_id(ap_id) do
def get_cached_by_ap_id(ap_id) do
- if Mix.env == :test do
+ if Mix.env
()
== :test do
get_by_ap_id(ap_id)
else
key = "object:#{ap_id}"
get_by_ap_id(ap_id)
else
key = "object:#{ap_id}"
- Cachex.get!(:user_cache, key, fallback: fn(_) ->
+
+ Cachex.fetch!(:user_cache, key, fn _ ->
object = get_by_ap_id(ap_id)
object = get_by_ap_id(ap_id)
+
if object do
{:commit, object}
else
if object do
{:commit, object}
else