From 1bd464fdc7a82452e398fc985126d08912f6d91f Mon Sep 17 00:00:00 2001 From: Edmondfrank Date: Mon, 21 Oct 2024 19:25:34 +0800 Subject: [PATCH] Finish replate redis with riak. Signed-off-by: Edmondfrank --- lib/compass_admin/application.ex | 2 -- .../plugs/verify_admin_plug.ex | 32 +++++++++---------- 2 files changed, 16 insertions(+), 18 deletions(-) diff --git a/lib/compass_admin/application.ex b/lib/compass_admin/application.ex index 2205d41..b85e079 100644 --- a/lib/compass_admin/application.ex +++ b/lib/compass_admin/application.ex @@ -42,8 +42,6 @@ defmodule CompassAdmin.Application do CompassAdminWeb.Endpoint, # Start Riak :poolboy.child_spec(:riak_pool, riak_config(), [riak_host, riak_port]), - # Start Redix - {Redix, {System.get_env("REDIS_URL") || redis_url, [name: :redix, backoff_max: 2_000, timeout: 2_000], }}, {Redlock, [ pool_size: 2, diff --git a/lib/compass_admin_web/plugs/verify_admin_plug.ex b/lib/compass_admin_web/plugs/verify_admin_plug.ex index 16f58bc..da88d55 100644 --- a/lib/compass_admin_web/plugs/verify_admin_plug.ex +++ b/lib/compass_admin_web/plugs/verify_admin_plug.ex @@ -2,6 +2,9 @@ defmodule CompassAdminWeb.Plugs.VerifyAdminPlug do import Plug.Conn alias CompassAdmin.User + alias CompassAdmin.RiakPool + + @bucket "sessions" def init(options), do: options @@ -11,22 +14,19 @@ defmodule CompassAdminWeb.Plugs.VerifyAdminPlug do defp verify_access!(conn, _opts) do session = conn.cookies["session"] - - case Redix.command(:redix, ["GET", "https://#{conn.host}:session:#{session}"]) do - {:ok, session_data} when session_data != nil -> - %{"warden.user.user.key" => [[id], parted_crypted_pass]} = ExMarshal.decode(session_data) - user = User.find(id) - - if user && String.slice(user.encrypted_password, 0..28) == parted_crypted_pass && - user.role_level > User.normal_role() do - conn - |> put_session(:current_user, user) - else - conn - |> auth_error() - |> halt() - end - + with session_data <- Riak.find(RiakPool.conn, @bucket, "https://#{conn.host}:session:#{session}"), + true <- session_data != nil, + %{ + "expiry" => expiry, + "timestamp" => timestamp, + "data" => %{ "warden.user.user.key" => [[id], parted_crypted_pass] } + } <- session_data.data |> Jason.decode!() |> Jason.decode!(), + true <- (timestamp + expiry) > Timex.to_unix(Timex.now), + user <- User.find(id), + true <- (user && String.slice(user.encrypted_password, 0..28) == parted_crypted_pass) do + conn + |> put_session(:current_user, user) + else _ -> conn |> auth_error()