2017-03-21 09:21:52 +01:00
|
|
|
defmodule Pleroma.Object do
|
|
|
|
use Ecto.Schema
|
2017-03-30 18:07:01 +02:00
|
|
|
alias Pleroma.{Repo, Object}
|
2017-05-09 18:11:51 +02:00
|
|
|
import Ecto.{Query, Changeset}
|
2017-03-21 09:21:52 +01:00
|
|
|
|
|
|
|
schema "objects" do
|
|
|
|
field :data, :map
|
|
|
|
|
|
|
|
timestamps()
|
|
|
|
end
|
2017-03-30 18:07:01 +02:00
|
|
|
|
2017-05-09 18:11:51 +02:00
|
|
|
def change(struct, params \\ %{}) do
|
|
|
|
changeset = struct
|
|
|
|
|> cast(params, [:data])
|
|
|
|
|> validate_required([:data])
|
|
|
|
|> unique_constraint(:ap_id, name: :objects_unique_apid_index)
|
|
|
|
end
|
|
|
|
|
2017-03-30 18:07:01 +02:00
|
|
|
def get_by_ap_id(ap_id) do
|
|
|
|
Repo.one(from object in Object,
|
|
|
|
where: fragment("? @> ?", object.data, ^%{id: ap_id}))
|
|
|
|
end
|
2017-04-30 13:53:26 +02:00
|
|
|
|
2017-05-01 16:12:20 +02:00
|
|
|
def get_cached_by_ap_id(ap_id) do
|
|
|
|
if Mix.env == :test do
|
|
|
|
get_by_ap_id(ap_id)
|
|
|
|
else
|
|
|
|
key = "object:#{ap_id}"
|
2017-05-01 16:28:40 +02:00
|
|
|
Cachex.get!(:user_cache, key, fallback: fn(_) ->
|
|
|
|
object = get_by_ap_id(ap_id)
|
|
|
|
if object do
|
|
|
|
{:commit, object}
|
|
|
|
else
|
|
|
|
{:ignore, object}
|
|
|
|
end
|
|
|
|
end)
|
2017-05-01 16:12:20 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-04-30 13:53:26 +02:00
|
|
|
def context_mapping(context) do
|
|
|
|
%Object{data: %{"id" => context}}
|
|
|
|
end
|
2017-03-21 09:21:52 +01:00
|
|
|
end
|