projects
/
akkoma
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix Reblog API
[akkoma]
/
lib
/
pleroma
/
web
/
auth
/
ldap_authenticator.ex
diff --git
a/lib/pleroma/web/auth/ldap_authenticator.ex
b/lib/pleroma/web/auth/ldap_authenticator.ex
index f667da68b90fa726a04c84c8e0ec41cdcf878455..17e08a2a6dfed05967ef758109594a664ed3036f 100644
(file)
--- a/
lib/pleroma/web/auth/ldap_authenticator.ex
+++ b/
lib/pleroma/web/auth/ldap_authenticator.ex
@@
-1,5
+1,5
@@
# Pleroma: A lightweight social networking server
# Pleroma: A lightweight social networking server
-# Copyright © 2017-202
0
Pleroma Authors <https://pleroma.social/>
+# Copyright © 2017-202
1
Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Web.Auth.LDAPAuthenticator do
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Web.Auth.LDAPAuthenticator do
@@
-103,14
+103,20
@@
defmodule Pleroma.Web.Auth.LDAPAuthenticator do
{:scope, :eldap.wholeSubtree()},
{:timeout, @search_timeout}
]) do
{:scope, :eldap.wholeSubtree()},
{:timeout, @search_timeout}
]) do
- {:ok, {:eldap_search_result, [{:eldap_entry, _,
_
}], _}} ->
+ {:ok, {:eldap_search_result, [{:eldap_entry, _,
attributes
}], _}} ->
params = %{
name: name,
nickname: name,
password: nil
}
params = %{
name: name,
nickname: name,
password: nil
}
- changeset = User.register_changeset(%User{}, params)
+ params =
+ case List.keyfind(attributes, 'mail', 0) do
+ {_, [mail]} -> Map.put_new(params, :email, :erlang.list_to_binary(mail))
+ _ -> params
+ end
+
+ changeset = User.register_changeset_ldap(%User{}, params)
case User.register(changeset) do
{:ok, user} -> user
case User.register(changeset) do
{:ok, user} -> user