diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/user.ex | 4 | ||||
| -rw-r--r-- | lib/pleroma/web/auth/pleroma_authenticator.ex | 11 | ||||
| -rw-r--r-- | lib/pleroma/web/oauth/oauth_controller.ex | 6 | 
3 files changed, 17 insertions, 4 deletions
| diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index cae2c14e3..d9f7e14b0 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -370,8 +370,8 @@ defmodule Pleroma.User do      ap_followers = followed.follower_address      cond do -      following?(follower, followed) or info.deactivated -> -        {:error, "Could not follow user: #{followed.nickname} is already on your list."} +      info.deactivated -> +        {:error, "Could not follow user: You are deactivated."}        deny_follow_blocked and blocks?(followed, follower) ->          {:error, "Could not follow user: #{followed.nickname} blocked you."} diff --git a/lib/pleroma/web/auth/pleroma_authenticator.ex b/lib/pleroma/web/auth/pleroma_authenticator.ex index c4a6fce08..a9164ad98 100644 --- a/lib/pleroma/web/auth/pleroma_authenticator.ex +++ b/lib/pleroma/web/auth/pleroma_authenticator.ex @@ -24,6 +24,14 @@ defmodule Pleroma.Web.Auth.PleromaAuthenticator do      end    end +  @doc """ +  Gets or creates Pleroma.Registration record from Ueberauth assigns. +  Note: some strategies (like `keycloak`) might need extra configuration to fill `uid` from callback response — +    see [`docs/config.md`](docs/config.md). +  """ +  def get_registration(%Plug.Conn{assigns: %{ueberauth_auth: %{uid: nil}}}), +    do: {:error, :missing_uid} +    def get_registration(%Plug.Conn{          assigns: %{ueberauth_auth: %{provider: provider, uid: uid} = auth}        }) do @@ -51,9 +59,10 @@ defmodule Pleroma.Web.Auth.PleromaAuthenticator do    def get_registration(%Plug.Conn{} = _conn), do: {:error, :missing_credentials} +  @doc "Creates Pleroma.User record basing on params and Pleroma.Registration record."    def create_from_registration(          %Plug.Conn{params: %{"authorization" => registration_attrs}}, -        registration +        %Registration{} = registration        ) do      nickname = value([registration_attrs["nickname"], Registration.nickname(registration)])      email = value([registration_attrs["email"], Registration.email(registration)]) diff --git a/lib/pleroma/web/oauth/oauth_controller.ex b/lib/pleroma/web/oauth/oauth_controller.ex index ae2b80d95..79d803295 100644 --- a/lib/pleroma/web/oauth/oauth_controller.ex +++ b/lib/pleroma/web/oauth/oauth_controller.ex @@ -17,6 +17,8 @@ defmodule Pleroma.Web.OAuth.OAuthController do    alias Pleroma.Web.OAuth.Token.Strategy.Revoke, as: RevokeToken    alias Pleroma.Web.OAuth.Scopes +  require Logger +    if Pleroma.Config.oauth_consumer_enabled?(), do: plug(Ueberauth)    plug(:fetch_session) @@ -318,7 +320,9 @@ defmodule Pleroma.Web.OAuth.OAuthController do            |> registration_details(%{"authorization" => registration_params})        end      else -      _ -> +      error -> +        Logger.debug(inspect(["OAUTH_ERROR", error, conn.assigns])) +          conn          |> put_flash(:error, "Failed to set up user account.")          |> redirect(external: redirect_uri(conn, params["redirect_uri"])) | 
