// Copyright 2016 Documize Inc. . All rights reserved. // // This software (Documize Community Edition) is licensed under // GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html // // You can operate outside the AGPL restrictions by purchasing // Documize Enterprise Edition and obtaining a commercial license // by contacting . // // https://documize.com package ldap import ( "crypto/tls" "fmt" "testing" lm "github.com/documize/community/model/auth" ld "gopkg.in/ldap.v2" ) func TestPublicLDAPServer(t *testing.T) { c := lm.LDAPConfig{} c.ServerHost = "ldap.forumsys.com" c.ServerPort = 389 c.EncryptionType = "none" c.BaseDN = "dc=example,dc=com" c.BindDN = "cn=read-only-admin,dc=example,dc=com" c.BindPassword = "password" c.GroupFilter = "" address := fmt.Sprintf("%s:%d", c.ServerHost, c.ServerPort) t.Log("Connecting to LDAP server ", address) l, err := ld.Dial("tcp", address) if err != nil { t.Error("Error: unable to dial LDAP server: ", err.Error()) return } defer l.Close() if c.EncryptionType == "starttls" { t.Log("Using StartTLS with LDAP server") err = l.StartTLS(&tls.Config{InsecureSkipVerify: true}) if err != nil { t.Error("Error: unable to startTLS with LDAP server: ", err.Error()) return } } // Authenticate with LDAP server using admin credentials. t.Log("Binding LDAP admin user") err = l.Bind(c.BindDN, c.BindPassword) if err != nil { t.Error("Error: unable to bind specified admin user to LDAP: ", err.Error()) return } // Get users from LDAP server by using filter filter := "" attrs := []string{} if len(c.GroupFilter) > 0 { filter = fmt.Sprintf("(&(objectClass=group)(cn=%s))", c.GroupFilter) attrs = []string{"cn"} } else { filter = "(|(objectClass=person)(objectClass=user)(objectClass=inetOrgPerson))" attrs = []string{"dn", "cn", "givenName", "sn", "mail", "uid"} } searchRequest := ld.NewSearchRequest( c.BaseDN, ld.ScopeWholeSubtree, ld.NeverDerefAliases, 0, 0, false, filter, attrs, nil, ) sr, err := l.Search(searchRequest) if err != nil { t.Error("Error: unable to execute directory search: ", err.Error()) return } t.Logf("entries found: %d", len(sr.Entries)) if len(sr.Entries) == 0 { t.Error("Received ZERO entries") return } for _, entry := range sr.Entries { fmt.Printf("[%s] %s (%s %s) @ %s\n", entry.GetAttributeValue("uid"), entry.GetAttributeValue("cn"), entry.GetAttributeValue("givenName"), entry.GetAttributeValue("sn"), entry.GetAttributeValue("mail")) } } func TestLocalLDAPServer(t *testing.T) { c := lm.LDAPConfig{} c.ServerHost = "127.0.0.1" c.ServerPort = 389 c.EncryptionType = "starttls" c.BaseDN = "ou=people,dc=planetexpress,dc=com" c.BindDN = "cn=admin,dc=planetexpress,dc=com" c.BindPassword = "GoodNewsEveryone" c.GroupFilter = "" address := fmt.Sprintf("%s:%d", c.ServerHost, c.ServerPort) t.Log("Connecting to LDAP server", address) l, err := ld.Dial("tcp", address) if err != nil { t.Error("Error: unable to dial LDAP server: ", err.Error()) return } defer l.Close() if c.EncryptionType == "starttls" { t.Log("Using StartTLS with LDAP server") err = l.StartTLS(&tls.Config{InsecureSkipVerify: true}) if err != nil { t.Error("Error: unable to startTLS with LDAP server: ", err.Error()) return } } // Authenticate with LDAP server using admin credentials. t.Log("Binding LDAP admin user") err = l.Bind(c.BindDN, c.BindPassword) if err != nil { t.Error("Error: unable to bind specified admin user to LDAP: ", err.Error()) return } // Get users from LDAP server by using filter filter := "" attrs := []string{} if len(c.GroupFilter) > 0 { filter = fmt.Sprintf("(&(objectClass=group)(cn=%s))", c.GroupFilter) attrs = []string{"cn"} } else { filter = "(|(objectClass=person)(objectClass=user)(objectClass=inetOrgPerson))" attrs = []string{"dn", "cn", "givenName", "sn", "mail", "uid"} } searchRequest := ld.NewSearchRequest( c.BaseDN, ld.ScopeWholeSubtree, ld.NeverDerefAliases, 0, 0, false, filter, attrs, nil, ) sr, err := l.Search(searchRequest) if err != nil { t.Error("Error: unable to execute directory search: ", err.Error()) return } t.Logf("entries found: %d", len(sr.Entries)) if len(sr.Entries) == 0 { t.Error("Received ZERO entries") return } for _, entry := range sr.Entries { fmt.Printf("[%s] %s (%s %s) @ %s\n", entry.GetAttributeValue("uid"), entry.GetAttributeValue("cn"), entry.GetAttributeValue("givenName"), entry.GetAttributeValue("sn"), entry.GetAttributeValue("mail")) } }