aboutsummaryrefslogtreecommitdiffstats
path: root/modules/auth
diff options
context:
space:
mode:
authorDenis Denisov <denji@users.noreply.github.com>2016-12-12 02:46:51 +0200
committerLunny Xiao <xiaolunwen@gmail.com>2016-12-12 08:46:51 +0800
commitf0a989c1d0843ab47a48be5219470a93a462e302 (patch)
treec6bb94aa8dc71559d5f69540a85b3ca928d26b8a /modules/auth
parentabcd39f7d52f6a9498b5f09a1d90c87da7c66909 (diff)
downloadgitea-f0a989c1d0843ab47a48be5219470a93a462e302.tar.gz
gitea-f0a989c1d0843ab47a48be5219470a93a462e302.zip
Correction LDAP validation (#342)
* Correction LDAP username validation As https://msdn.microsoft.com/en-us/library/aa366101(v=vs.85).aspx describe spaces should not be in start or at the end of username but they can be inside the username. So please check my solution for it. * Check for zero length passwords in LDAP module. According to https://tools.ietf.org/search/rfc4513#section-5.1.2 LDAP client should always check before bind whether a password is an empty value. There are at least one LDAP implementation which does not return error if you try to bind with DN set and empty password - AD. * Clearing the login/email spaces at the [start/end]
Diffstat (limited to 'modules/auth')
-rw-r--r--modules/auth/ldap/ldap.go5
1 files changed, 5 insertions, 0 deletions
diff --git a/modules/auth/ldap/ldap.go b/modules/auth/ldap/ldap.go
index 0cabcb20a0..3064b31958 100644
--- a/modules/auth/ldap/ldap.go
+++ b/modules/auth/ldap/ldap.go
@@ -151,6 +151,11 @@ func bindUser(l *ldap.Conn, userDN, passwd string) error {
// SearchEntry : search an LDAP source if an entry (name, passwd) is valid and in the specific filter
func (ls *Source) SearchEntry(name, passwd string, directBind bool) (string, string, string, string, bool, bool) {
+ // See https://tools.ietf.org/search/rfc4513#section-5.1.2
+ if len(passwd) == 0 {
+ log.Debug("Auth. failed for %s, password cannot be empty")
+ return "", "", "", "", false, false
+ }
l, err := dial(ls)
if err != nil {
log.Error(4, "LDAP Connect error, %s:%v", ls.Host, err)