2018-12-23 12:04:54 -08:00
|
|
|
# Pleroma: A lightweight social networking server
|
2018-12-31 07:41:47 -08:00
|
|
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 12:04:54 -08:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-08-13 19:27:28 -07:00
|
|
|
defmodule Pleroma.Filter do
|
|
|
|
use Ecto.Schema
|
2019-02-09 07:16:26 -08:00
|
|
|
|
|
|
|
import Ecto.Changeset
|
|
|
|
import Ecto.Query
|
|
|
|
|
|
|
|
alias Pleroma.Repo
|
2019-03-04 18:52:23 -08:00
|
|
|
alias Pleroma.User
|
2018-08-13 19:27:28 -07:00
|
|
|
|
|
|
|
schema "filters" do
|
2019-09-18 07:54:31 -07:00
|
|
|
belongs_to(:user, User, type: FlakeId.Ecto.CompatType)
|
2018-08-13 19:27:28 -07:00
|
|
|
field(:filter_id, :integer)
|
|
|
|
field(:hide, :boolean, default: false)
|
|
|
|
field(:whole_word, :boolean, default: true)
|
|
|
|
field(:phrase, :string)
|
|
|
|
field(:context, {:array, :string})
|
|
|
|
field(:expires_at, :utc_datetime)
|
|
|
|
|
|
|
|
timestamps()
|
|
|
|
end
|
|
|
|
|
|
|
|
def get(id, %{id: user_id} = _user) do
|
|
|
|
query =
|
|
|
|
from(
|
|
|
|
f in Pleroma.Filter,
|
|
|
|
where: f.filter_id == ^id,
|
|
|
|
where: f.user_id == ^user_id
|
|
|
|
)
|
|
|
|
|
|
|
|
Repo.one(query)
|
|
|
|
end
|
|
|
|
|
2018-12-09 01:12:48 -08:00
|
|
|
def get_filters(%User{id: user_id} = _user) do
|
2018-08-13 19:27:28 -07:00
|
|
|
query =
|
|
|
|
from(
|
|
|
|
f in Pleroma.Filter,
|
2019-05-15 09:23:01 -07:00
|
|
|
where: f.user_id == ^user_id,
|
|
|
|
order_by: [desc: :id]
|
2018-08-13 19:27:28 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
Repo.all(query)
|
|
|
|
end
|
|
|
|
|
2018-10-11 22:19:43 -07:00
|
|
|
def create(%Pleroma.Filter{user_id: user_id, filter_id: nil} = filter) do
|
|
|
|
# If filter_id wasn't given, use the max filter_id for this user plus 1.
|
2018-12-09 01:12:48 -08:00
|
|
|
# XXX This could result in a race condition if a user tries to add two
|
|
|
|
# different filters for their account from two different clients at the
|
|
|
|
# same time, but that should be unlikely.
|
2018-10-11 22:19:43 -07:00
|
|
|
|
|
|
|
max_id_query =
|
|
|
|
from(
|
|
|
|
f in Pleroma.Filter,
|
|
|
|
where: f.user_id == ^user_id,
|
|
|
|
select: max(f.filter_id)
|
|
|
|
)
|
|
|
|
|
|
|
|
filter_id =
|
|
|
|
case Repo.one(max_id_query) do
|
|
|
|
# Start allocating from 1
|
|
|
|
nil ->
|
|
|
|
1
|
|
|
|
|
|
|
|
max_id ->
|
|
|
|
max_id + 1
|
|
|
|
end
|
|
|
|
|
|
|
|
filter
|
|
|
|
|> Map.put(:filter_id, filter_id)
|
|
|
|
|> Repo.insert()
|
|
|
|
end
|
|
|
|
|
2018-08-13 19:27:28 -07:00
|
|
|
def create(%Pleroma.Filter{} = filter) do
|
|
|
|
Repo.insert(filter)
|
|
|
|
end
|
|
|
|
|
|
|
|
def delete(%Pleroma.Filter{id: filter_key} = filter) when is_number(filter_key) do
|
|
|
|
Repo.delete(filter)
|
|
|
|
end
|
|
|
|
|
|
|
|
def delete(%Pleroma.Filter{id: filter_key} = filter) when is_nil(filter_key) do
|
|
|
|
%Pleroma.Filter{id: id} = get(filter.filter_id, %{id: filter.user_id})
|
|
|
|
|
|
|
|
filter
|
|
|
|
|> Map.put(:id, id)
|
|
|
|
|> Repo.delete()
|
|
|
|
end
|
|
|
|
|
|
|
|
def update(%Pleroma.Filter{} = filter) do
|
|
|
|
destination = Map.from_struct(filter)
|
|
|
|
|
|
|
|
Pleroma.Filter.get(filter.filter_id, %{id: filter.user_id})
|
|
|
|
|> cast(destination, [:phrase, :context, :hide, :expires_at, :whole_word])
|
|
|
|
|> Repo.update()
|
|
|
|
end
|
|
|
|
end
|