aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorRoger Braun <roger@rogerbraun.net>2017-05-10 10:16:20 +0200
committerRoger Braun <roger@rogerbraun.net>2017-05-10 10:16:20 +0200
commit118c572006dd96e6718035e5859aa339aa254476 (patch)
tree4acfdd022c02b8d2a4f56bd0cbd2f4b64f172479 /lib
parent373753e595de96a0492edfc6cc180c3e47696a55 (diff)
downloadpleroma-118c572006dd96e6718035e5859aa339aa254476.tar.gz
Use changeset for remote user creation.
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/user.ex7
-rw-r--r--lib/pleroma/web/ostatus/ostatus.ex6
2 files changed, 6 insertions, 7 deletions
diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex
index 9b2433674..22e77c3df 100644
--- a/lib/pleroma/user.ex
+++ b/lib/pleroma/user.ex
@@ -63,13 +63,14 @@ defmodule Pleroma.User do
@email_regex ~r/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/
def remote_user_creation(params) do
- changeset = %User{}
- |> cast(params, [:bio, :name, :ap_id, :nickname, :info])
- |> validate_required([:bio, :name, :ap_id, :nickname])
+ %User{}
+ |> cast(params, [:bio, :name, :ap_id, :nickname, :info, :avatar])
+ |> validate_required([:name, :ap_id, :nickname])
|> unique_constraint(:nickname)
|> validate_format(:nickname, @email_regex)
|> validate_length(:bio, max: 1000)
|> validate_length(:name, max: 100)
+ |> put_change(:local, false)
end
def register_changeset(struct, params \\ %{}) do
diff --git a/lib/pleroma/web/ostatus/ostatus.ex b/lib/pleroma/web/ostatus/ostatus.ex
index 55d600ab2..da0407aeb 100644
--- a/lib/pleroma/web/ostatus/ostatus.ex
+++ b/lib/pleroma/web/ostatus/ostatus.ex
@@ -211,16 +211,14 @@ defmodule Pleroma.Web.OStatus do
def make_user(uri) do
with {:ok, info} <- gather_user_info(uri) do
data = %{
- local: false,
name: info["name"],
nickname: info["nickname"] <> "@" <> info["host"],
ap_id: info["uri"],
info: info,
avatar: info["avatar"]
}
- # TODO: Make remote user changeset
- # SHould enforce fqn nickname
- Repo.insert(Ecto.Changeset.change(%User{}, data))
+ cs = User.remote_user_creation(data)
+ Repo.insert(cs)
end
end