aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorRoger Braun <roger@rogerbraun.net>2017-04-30 18:48:48 +0200
committerRoger Braun <roger@rogerbraun.net>2017-04-30 18:48:48 +0200
commitbed0b398139897ebe9f839d1263acf6934c4a42f (patch)
tree1866c7ff5f489bac5f3cdf61996c1b95dad07f02 /lib
parenteb12a89d22c09bccad7cb13780e0313de8be8e93 (diff)
downloadpleroma-bed0b398139897ebe9f839d1263acf6934c4a42f.tar.gz
Add function to fetch users from fqn.
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/user.ex12
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex
index 58f89a915..c264d7e90 100644
--- a/lib/pleroma/user.ex
+++ b/lib/pleroma/user.ex
@@ -3,6 +3,7 @@ defmodule Pleroma.User do
import Ecto.Changeset
import Ecto.Query
alias Pleroma.{Repo, User, Activity, Object}
+ alias Pleroma.Web.OStatus
schema "users" do
field :bio, :string
@@ -131,4 +132,15 @@ defmodule Pleroma.User do
key = "user_info:#{user.id}"
Cachex.get!(:user_cache, key, fallback: fn(_) -> user_info(user) end)
end
+
+ def get_or_fetch_by_nickname(nickname) do
+ with %User{} = user <- get_by_nickname(nickname) do
+ user
+ else _e ->
+ with {:ok, user} <- OStatus.make_user(nickname) do
+ user
+ else _e -> nil
+ end
+ end
+ end
end