mirror of
https://github.com/philomena-dev/philomena.git
synced 2025-01-20 06:37:59 +01:00
127 lines
3.5 KiB
Elixir
127 lines
3.5 KiB
Elixir
defmodule Philomena.DuplicateReports do
|
|
@moduledoc """
|
|
The DuplicateReports context.
|
|
"""
|
|
|
|
import Ecto.Query, warn: false
|
|
alias Philomena.Repo
|
|
|
|
alias Philomena.DuplicateReports.DuplicateReport
|
|
alias Philomena.ImageIntensities.ImageIntensity
|
|
alias Philomena.Images.Image
|
|
|
|
def generate_reports(source) do
|
|
source = Repo.preload(source, :intensity)
|
|
|
|
duplicates_of(source.intensity, source.image_aspect_ratio, 0.2, 0.05)
|
|
|> where([i, _it], i.id != ^source.id)
|
|
|> where([i, _it], i.duplication_checked != true)
|
|
|> Repo.all()
|
|
|> Enum.map(fn target ->
|
|
create_duplicate_report(source, target, %{}, %{"reason" => "Automated Perceptual dedupe match"})
|
|
end)
|
|
end
|
|
|
|
def duplicates_of(intensities, aspect_ratio, dist \\ 0.25, aspect_dist \\ 0.05) do
|
|
from i in Image,
|
|
inner_join: it in ImageIntensity,
|
|
on: it.image_id == i.id,
|
|
where: it.nw >= ^(intensities.nw - dist) and it.nw <= ^(intensities.nw + dist),
|
|
where: it.ne >= ^(intensities.ne - dist) and it.ne <= ^(intensities.ne + dist),
|
|
where: it.sw >= ^(intensities.sw - dist) and it.sw <= ^(intensities.sw + dist),
|
|
where: it.se >= ^(intensities.se - dist) and it.se <= ^(intensities.se + dist),
|
|
where: i.image_aspect_ratio >= ^(aspect_ratio - aspect_dist) and i.image_aspect_ratio <= ^(aspect_ratio + aspect_dist),
|
|
limit: 20
|
|
end
|
|
|
|
@doc """
|
|
Gets a single duplicate_report.
|
|
|
|
Raises `Ecto.NoResultsError` if the Duplicate report does not exist.
|
|
|
|
## Examples
|
|
|
|
iex> get_duplicate_report!(123)
|
|
%DuplicateReport{}
|
|
|
|
iex> get_duplicate_report!(456)
|
|
** (Ecto.NoResultsError)
|
|
|
|
"""
|
|
def get_duplicate_report!(id), do: Repo.get!(DuplicateReport, id)
|
|
|
|
@doc """
|
|
Creates a duplicate_report.
|
|
|
|
## Examples
|
|
|
|
iex> create_duplicate_report(%{field: value})
|
|
{:ok, %DuplicateReport{}}
|
|
|
|
iex> create_duplicate_report(%{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def create_duplicate_report(source, target, attribution, attrs \\ %{}) do
|
|
%DuplicateReport{image_id: source.id, duplicate_of_image_id: target.id}
|
|
|> DuplicateReport.creation_changeset(attrs, attribution)
|
|
|> Repo.insert()
|
|
end
|
|
|
|
@doc """
|
|
Updates a duplicate_report.
|
|
|
|
## Examples
|
|
|
|
iex> update_duplicate_report(duplicate_report, %{field: new_value})
|
|
{:ok, %DuplicateReport{}}
|
|
|
|
iex> update_duplicate_report(duplicate_report, %{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def update_duplicate_report(%DuplicateReport{} = duplicate_report, attrs) do
|
|
duplicate_report
|
|
|> DuplicateReport.changeset(attrs)
|
|
|> Repo.update()
|
|
end
|
|
|
|
@doc """
|
|
Deletes a DuplicateReport.
|
|
|
|
## Examples
|
|
|
|
iex> delete_duplicate_report(duplicate_report)
|
|
{:ok, %DuplicateReport{}}
|
|
|
|
iex> delete_duplicate_report(duplicate_report)
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def delete_duplicate_report(%DuplicateReport{} = duplicate_report) do
|
|
Repo.delete(duplicate_report)
|
|
end
|
|
|
|
@doc """
|
|
Returns an `%Ecto.Changeset{}` for tracking duplicate_report changes.
|
|
|
|
## Examples
|
|
|
|
iex> change_duplicate_report(duplicate_report)
|
|
%Ecto.Changeset{source: %DuplicateReport{}}
|
|
|
|
"""
|
|
def change_duplicate_report(%DuplicateReport{} = duplicate_report) do
|
|
DuplicateReport.changeset(duplicate_report, %{})
|
|
end
|
|
|
|
def count_duplicate_reports(user) do
|
|
if Canada.Can.can?(user, :manage, DuplicateReport) do
|
|
DuplicateReport
|
|
|> where(state: "open")
|
|
|> Repo.aggregate(:count, :id)
|
|
else
|
|
nil
|
|
end
|
|
end
|
|
end
|