Pleroma/lib/pleroma/plugs/http_signature.ex

41 lines
993 B
Elixir
Raw Normal View History

defmodule Pleroma.Web.Plugs.HTTPSignaturePlug do
alias Pleroma.Web.HTTPSignatures
alias Pleroma.Web.ActivityPub.Utils
import Plug.Conn
2018-02-22 14:57:35 +01:00
require Logger
def init(options) do
options
end
def call(%{assigns: %{valid_signature: true}} = conn, _opts) do
conn
end
def call(conn, _opts) do
user = Utils.normalize_actor(conn.params["actor"])
2018-02-22 14:57:35 +01:00
Logger.debug("Checking sig for #{user}")
2018-04-02 13:13:14 +02:00
[signature | _] = get_req_header(conn, "signature")
2018-03-11 14:37:23 +01:00
2018-04-02 13:13:14 +02:00
cond do
signature && String.contains?(signature, user) ->
conn =
conn
|> put_req_header(
"(request-target)",
String.downcase("#{conn.method}") <> " #{conn.request_path}"
)
assign(conn, :valid_signature, HTTPSignatures.validate_conn(conn))
2018-04-02 13:13:14 +02:00
signature ->
Logger.debug("Signature not from actor")
assign(conn, :valid_signature, false)
true ->
Logger.debug("No signature header!")
conn
end
end
end