2017-03-21 08:21:52 +00:00
|
|
|
defmodule Pleroma.Object do
|
|
|
|
use Ecto.Schema
|
2017-03-30 17:07:01 +01:00
|
|
|
alias Pleroma.{Repo, Object}
|
2017-05-09 17:11:51 +01:00
|
|
|
import Ecto.{Query, Changeset}
|
2017-03-21 08:21:52 +00:00
|
|
|
|
|
|
|
schema "objects" do
|
|
|
|
field :data, :map
|
|
|
|
|
|
|
|
timestamps()
|
|
|
|
end
|
2017-03-30 17:07:01 +01:00
|
|
|
|
2017-05-16 14:31:11 +01:00
|
|
|
def create(data) do
|
|
|
|
Object.change(%Object{}, %{data: data})
|
|
|
|
|> Repo.insert
|
|
|
|
end
|
|
|
|
|
2017-05-09 17:11:51 +01: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-10-24 07:39:24 +01:00
|
|
|
def get_by_ap_id(nil), do: nil
|
2017-03-30 17:07:01 +01:00
|
|
|
def get_by_ap_id(ap_id) do
|
|
|
|
Repo.one(from object in Object,
|
2017-10-24 09:39:23 +01:00
|
|
|
where: fragment("(?)->>'id' = ?", object.data, ^ap_id))
|
2017-03-30 17:07:01 +01:00
|
|
|
end
|
2017-04-30 12:53:26 +01:00
|
|
|
|
2017-05-01 15:12:20 +01: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 15:28:40 +01: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 15:12:20 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-04-30 12:53:26 +01:00
|
|
|
def context_mapping(context) do
|
2017-06-20 08:50:22 +01:00
|
|
|
Object.change(%Object{}, %{data: %{"id" => context}})
|
2017-04-30 12:53:26 +01:00
|
|
|
end
|
2017-03-21 08:21:52 +00:00
|
|
|
end
|