diff options
author | Roger Braun <roger@rogerbraun.net> | 2017-04-30 18:48:48 +0200 |
---|---|---|
committer | Roger Braun <roger@rogerbraun.net> | 2017-04-30 18:48:48 +0200 |
commit | bed0b398139897ebe9f839d1263acf6934c4a42f (patch) | |
tree | 1866c7ff5f489bac5f3cdf61996c1b95dad07f02 /lib | |
parent | eb12a89d22c09bccad7cb13780e0313de8be8e93 (diff) | |
download | pleroma-bed0b398139897ebe9f839d1263acf6934c4a42f.tar.gz |
Add function to fetch users from fqn.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/user.ex | 12 |
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 |