1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
package main
import (
"github.com/mark-rushakoff/ldapserver"
"log"
"net"
)
/////////////
// Sample searches you can try against this simple LDAP server:
//
// ldapsearch -H ldap://localhost:3389 -x -b 'dn=test,dn=com'
// ldapsearch -H ldap://localhost:3389 -x -b 'dn=test,dn=com' 'cn=ned'
// ldapsearch -H ldap://localhost:3389 -x -b 'dn=test,dn=com' 'uidnumber=5000'
/////////////
///////////// Run a simple LDAP server
func main() {
s := ldapserver.NewServer()
// register Bind and Search function handlers
handler := ldapHandler{}
s.BindFunc("", handler)
s.SearchFunc("", handler)
// start the server
listen := "localhost:3389"
log.Printf("Starting example LDAP server on %s", listen)
if err := s.ListenAndServe(listen); err != nil {
log.Fatal("LDAP Server Failed: %s", err.Error())
}
}
type ldapHandler struct {
}
///////////// Allow anonymous binds only
func (h ldapHandler) Bind(bindDN, bindSimplePw string, conn net.Conn) (ldapserver.LDAPResultCode, error) {
if bindDN == "" && bindSimplePw == "" {
return ldapserver.LDAPResultSuccess, nil
}
return ldapserver.LDAPResultInvalidCredentials, nil
}
///////////// Return some hardcoded search results - we'll respond to any baseDN for testing
func (h ldapHandler) Search(boundDN string, searchReq ldapserver.SearchRequest, conn net.Conn) (ldapserver.ServerSearchResult, error) {
entries := []*ldapserver.Entry{
&ldapserver.Entry{"cn=ned," + searchReq.BaseDN, []*ldapserver.EntryAttribute{
&ldapserver.EntryAttribute{"cn", []string{"ned"}},
&ldapserver.EntryAttribute{"uidNumber", []string{"5000"}},
&ldapserver.EntryAttribute{"accountStatus", []string{"active"}},
&ldapserver.EntryAttribute{"uid", []string{"ned"}},
&ldapserver.EntryAttribute{"description", []string{"ned"}},
&ldapserver.EntryAttribute{"objectClass", []string{"posixAccount"}},
}},
&ldapserver.Entry{"cn=trent," + searchReq.BaseDN, []*ldapserver.EntryAttribute{
&ldapserver.EntryAttribute{"cn", []string{"trent"}},
&ldapserver.EntryAttribute{"uidNumber", []string{"5005"}},
&ldapserver.EntryAttribute{"accountStatus", []string{"active"}},
&ldapserver.EntryAttribute{"uid", []string{"trent"}},
&ldapserver.EntryAttribute{"description", []string{"trent"}},
&ldapserver.EntryAttribute{"objectClass", []string{"posixAccount"}},
}},
}
return ldapserver.ServerSearchResult{entries, []string{}, []ldapserver.Control{}, ldapserver.LDAPResultSuccess}, nil
}
|