diff options
author | Roger Braun <roger@rogerbraun.net> | 2017-05-10 10:16:20 +0200 |
---|---|---|
committer | Roger Braun <roger@rogerbraun.net> | 2017-05-10 10:16:20 +0200 |
commit | 118c572006dd96e6718035e5859aa339aa254476 (patch) | |
tree | 4acfdd022c02b8d2a4f56bd0cbd2f4b64f172479 /lib | |
parent | 373753e595de96a0492edfc6cc180c3e47696a55 (diff) | |
download | pleroma-118c572006dd96e6718035e5859aa339aa254476.tar.gz |
Use changeset for remote user creation.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/user.ex | 7 | ||||
-rw-r--r-- | lib/pleroma/web/ostatus/ostatus.ex | 6 |
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 |