summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoger Braun <roger@rogerbraun.net>2017-05-01 22:02:07 +0200
committerRoger Braun <roger@rogerbraun.net>2017-05-01 22:02:07 +0200
commit89c1e90eb2a5da0a6f635a6158fe880076518a38 (patch)
tree02489476f098bb191026b39d026dd3f1f4aec116
parent8ae13d94dc69e4fcb7f454c2eb7665955c8e37fb (diff)
downloadpleroma-89c1e90eb2a5da0a6f635a6158fe880076518a38.tar.gz
pleroma-89c1e90eb2a5da0a6f635a6158fe880076518a38.zip
Don't crypt raw iolists.
-rw-r--r--lib/pleroma/web/websub/websub.ex3
-rw-r--r--test/web/websub/websub_test.exs7
2 files changed, 9 insertions, 1 deletions
diff --git a/lib/pleroma/web/websub/websub.ex b/lib/pleroma/web/websub/websub.ex
index 905c237a0..546bfb5a4 100644
--- a/lib/pleroma/web/websub/websub.ex
+++ b/lib/pleroma/web/websub/websub.ex
@@ -41,6 +41,7 @@ defmodule Pleroma.Web.Websub do
Enum.each(subscriptions, fn(sub) ->
response = FeedRepresenter.to_simple_form(user, [activity], [user])
|> :xmerl.export_simple(:xmerl_xml)
+ |> to_string
signature = sign(sub.secret, response)
HTTPoison.post(sub.callback, response, [
@@ -51,7 +52,7 @@ defmodule Pleroma.Web.Websub do
end
def sign(secret, doc) do
- :crypto.hmac(:sha, secret, doc) |> Base.encode16
+ :crypto.hmac(:sha, secret, to_string(doc)) |> Base.encode16
end
def incoming_subscription_request(user, %{"hub.mode" => "subscribe"} = params) do
diff --git a/test/web/websub/websub_test.exs b/test/web/websub/websub_test.exs
index ad312cd25..63acb3c43 100644
--- a/test/web/websub/websub_test.exs
+++ b/test/web/websub/websub_test.exs
@@ -167,4 +167,11 @@ defmodule Pleroma.Web.WebsubTest do
{:error, websub} = Websub.request_subscription(websub, poster, 1000)
assert websub.state == "rejected"
end
+
+ test "sign a text" do
+ signed = Websub.sign("secret", "text")
+ assert signed == "B8392C23690CCF871F37EC270BE1582DEC57A503"
+
+ signed = Websub.sign("secret", [["て"], ['す']])
+ end
end