projects
/
akkoma
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Hook up block/unblock to TwitterAPI
[akkoma]
/
lib
/
pleroma
/
object.ex
diff --git
a/lib/pleroma/object.ex
b/lib/pleroma/object.ex
index 72991fa1f028a3610867edc5cd5f8eec6d79c54d..558e151b093bac8a48f972cf2c81e2e9fa3404a3 100644
(file)
--- a/
lib/pleroma/object.ex
+++ b/
lib/pleroma/object.ex
@@
-4,45
+4,52
@@
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
def get_cached_by_ap_id(ap_id) do
end
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(_) ->
- object = get_by_ap_id(ap_id)
- if object do
- {:commit, object}
- else
- {:ignore, object}
+
+ Cachex.get!(
+ :user_cache,
+ key,
+ fallback: fn _ ->
+ object = get_by_ap_id(ap_id)
+
+ if object do
+ {:commit, object}
+ else
+ {:ignore, object}
+ end
end
end
-
end
)
+ )
end
end
def context_mapping(context) do
end
end
def context_mapping(context) do
- %Object{data: %{"id" => context}}
+ Object.change(%Object{}, %{data: %{"id" => context}})
end
end
end
end