2018-12-23 21:04:54 +01:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-03 23:44:49 +01:00
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 21:04:54 +01:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-08-01 01:17:47 +02:00
|
|
|
defmodule Pleroma.Web.Plugs.DigestPlug do
|
|
|
|
alias Plug.Conn
|
|
|
|
require Logger
|
|
|
|
|
|
|
|
def read_body(conn, opts) do
|
2020-11-26 09:12:44 +01:00
|
|
|
digest_algorithm =
|
|
|
|
with [digest_header] <- Conn.get_req_header(conn, "digest") do
|
|
|
|
digest_header
|
|
|
|
|> String.split("=", parts: 2)
|
|
|
|
|> List.first()
|
|
|
|
else
|
|
|
|
_ -> "SHA-256"
|
|
|
|
end
|
|
|
|
|
|
|
|
unless String.downcase(digest_algorithm) == "sha-256" do
|
|
|
|
raise ArgumentError,
|
|
|
|
message: "invalid value for digest algorithm, got: #{digest_algorithm}"
|
|
|
|
end
|
|
|
|
|
2018-08-01 01:17:47 +02:00
|
|
|
{:ok, body, conn} = Conn.read_body(conn, opts)
|
2020-11-26 09:12:44 +01:00
|
|
|
encoded_digest = :crypto.hash(:sha256, body) |> Base.encode64()
|
|
|
|
{:ok, body, Conn.assign(conn, :digest, "#{digest_algorithm}=#{encoded_digest}")}
|
2018-08-01 01:17:47 +02:00
|
|
|
end
|
|
|
|
end
|