aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/plugs/session_authentication_plug.ex
diff options
context:
space:
mode:
authorAlex Gleason <alex@alexgleason.me>2020-10-13 19:20:00 -0500
committerAlex Gleason <alex@alexgleason.me>2020-10-13 19:20:00 -0500
commitc3112fd13a6af239b9dff0813e93266ec58f571e (patch)
tree7f2252d7a08e4a59b66e392b2732a1cdd8745758 /lib/pleroma/web/plugs/session_authentication_plug.ex
parent66e00ace7c0708f2f9361bc6e1008ccea08cb6ef (diff)
parent481906207e6d803e5c4d3e455c7b93119e392177 (diff)
downloadpleroma-c3112fd13a6af239b9dff0813e93266ec58f571e.tar.gz
Merge remote-tracking branch 'upstream/develop' into registration-workflow
Diffstat (limited to 'lib/pleroma/web/plugs/session_authentication_plug.ex')
-rw-r--r--lib/pleroma/web/plugs/session_authentication_plug.ex21
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/pleroma/web/plugs/session_authentication_plug.ex b/lib/pleroma/web/plugs/session_authentication_plug.ex
new file mode 100644
index 000000000..6e176d553
--- /dev/null
+++ b/lib/pleroma/web/plugs/session_authentication_plug.ex
@@ -0,0 +1,21 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Web.Plugs.SessionAuthenticationPlug do
+ import Plug.Conn
+
+ def init(options) do
+ options
+ end
+
+ def call(conn, _) do
+ with saved_user_id <- get_session(conn, :user_id),
+ %{auth_user: %{id: ^saved_user_id}} <- conn.assigns do
+ conn
+ |> assign(:user, conn.assigns.auth_user)
+ else
+ _ -> conn
+ end
+ end
+end