akkoma/lib/pleroma/plugs/http_signature.ex

40 lines
932 B
Elixir
Raw Normal View History

defmodule Pleroma.Web.Plugs.HTTPSignaturePlug do
alias Pleroma.Web.HTTPSignatures
import Plug.Conn
2018-02-22 13:57:35 +00: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
2018-02-22 13:57:35 +00:00
user = conn.params["actor"]
Logger.debug("Checking sig for #{user}")
2018-04-02 11:13:14 +00:00
[signature | _] = get_req_header(conn, "signature")
2018-03-11 13:37:23 +00:00
2018-04-02 11:13:14 +00: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 11:13:14 +00:00
signature ->
Logger.debug("Signature not from actor")
assign(conn, :valid_signature, false)
true ->
Logger.debug("No signature header!")
conn
end
end
end