2020-05-18 00:22:26 -06:00
|
|
|
# Pleroma: A lightweight social networking server
|
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2020-05-16 06:16:33 -06:00
|
|
|
defmodule Pleroma.Web.MediaProxy.Invalidation.Http do
|
2020-05-18 00:22:26 -06:00
|
|
|
@moduledoc false
|
2020-05-16 06:16:33 -06:00
|
|
|
@behaviour Pleroma.Web.MediaProxy.Invalidation
|
|
|
|
|
2020-05-18 00:22:26 -06:00
|
|
|
require Logger
|
|
|
|
|
2020-05-16 06:16:33 -06:00
|
|
|
@impl Pleroma.Web.MediaProxy.Invalidation
|
|
|
|
def purge(urls, opts) do
|
2020-05-17 21:48:19 -06:00
|
|
|
method = Map.get(opts, :method, :purge)
|
|
|
|
headers = Map.get(opts, :headers, [])
|
|
|
|
options = Map.get(opts, :options, [])
|
2020-05-16 06:16:33 -06:00
|
|
|
|
2020-05-18 00:22:26 -06:00
|
|
|
Logger.debug("Running cache purge: #{inspect(urls)}")
|
|
|
|
|
2020-05-16 06:16:33 -06:00
|
|
|
Enum.each(urls, fn url ->
|
2020-05-18 00:22:26 -06:00
|
|
|
with {:error, error} <- do_purge(method, url, headers, options) do
|
|
|
|
Logger.error("Error while cache purge: url - #{url}, error: #{inspect(error)}")
|
|
|
|
end
|
2020-05-16 06:16:33 -06:00
|
|
|
end)
|
|
|
|
|
|
|
|
{:ok, "success"}
|
|
|
|
end
|
2020-05-18 00:22:26 -06:00
|
|
|
|
|
|
|
defp do_purge(method, url, headers, options) do
|
|
|
|
case Pleroma.HTTP.request(method, url, "", headers, options) do
|
|
|
|
{:ok, %{status: status} = env} when 400 <= status and status < 500 ->
|
|
|
|
{:error, env}
|
|
|
|
|
|
|
|
{:error, error} = error ->
|
|
|
|
error
|
|
|
|
|
|
|
|
_ ->
|
|
|
|
{:ok, "success"}
|
|
|
|
end
|
|
|
|
end
|
2020-05-16 06:16:33 -06:00
|
|
|
end
|