func handleSearch(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() log.Printf("Request BaseDn=%s", r.GetBaseObject()) log.Printf("Request Filter=%s", r.GetFilter()) log.Printf("Request Attributes=%s", r.GetAttributes()) // Handle Stop Signal (server stop / client disconnected / Abandoned request....) select { case <-m.Done: log.Print("Leaving handleSearch...") return default: } e := ldap.NewSearchResultEntry() e.SetDn("cn=Valere JEANTET, " + string(r.GetBaseObject())) e.AddAttribute("mail", "*****@*****.**", "*****@*****.**") e.AddAttribute("company", "SODADI") e.AddAttribute("department", "DSI/SEC") e.AddAttribute("l", "Ferrieres en brie") e.AddAttribute("mobile", "0612324567") e.AddAttribute("telephoneNumber", "0612324567") e.AddAttribute("cn", "Valère JEANTET") w.Write(e) e = ldap.NewSearchResultEntry() e.SetDn("cn=Claire Thomas, " + string(r.GetBaseObject())) e.AddAttribute("mail", "*****@*****.**") e.AddAttribute("cn", "Claire THOMAS") w.Write(e) res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }
func handleSearch(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() log.Printf("Request BaseDn=%s", r.BaseObject()) log.Printf("Request Filter=%s", r.FilterString()) log.Printf("Request Attributes=%s", r.Attributes()) // Handle Stop Signal (server stop / client disconnected / Abandoned request....) for { select { case <-m.Done: log.Printf("Leaving handleSearch... for msgid=%d", m.MessageID) return default: } e := ldap.NewSearchResultEntry("cn=Valere JEANTET, " + string(r.BaseObject())) e.AddAttribute("mail", "*****@*****.**", "*****@*****.**") e.AddAttribute("company", "SODADI") e.AddAttribute("department", "DSI/SEC") e.AddAttribute("l", "Ferrieres en brie") e.AddAttribute("mobile", "0612324567") e.AddAttribute("telephoneNumber", "0612324567") e.AddAttribute("cn", "Valère JEANTET") w.Write(e) time.Sleep(time.Millisecond * 800) } res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }
func handleSearchDSE(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() log.Printf("Request BaseDn=%s", r.BaseObject()) log.Printf("Request Filter=%s", r.Filter()) log.Printf("Request FilterString=%s", r.FilterString()) log.Printf("Request Attributes=%s", r.Attributes()) log.Printf("Request TimeLimit=%d", r.TimeLimit().Int()) e := ldap.NewSearchResultEntry("") e.AddAttribute("vendorName", "Valère JEANTET") e.AddAttribute("vendorVersion", "0.0.1") e.AddAttribute("objectClass", "top", "extensibleObject") e.AddAttribute("supportedLDAPVersion", "3") e.AddAttribute("namingContexts", "o=My Company, c=US") // e.AddAttribute("subschemaSubentry", "cn=schema") // e.AddAttribute("namingContexts", "ou=system", "ou=schema", "dc=example,dc=com", "ou=config") // e.AddAttribute("supportedFeatures", "1.3.6.1.4.1.4203.1.5.1") // e.AddAttribute("supportedControl", "2.16.840.1.113730.3.4.3", "1.3.6.1.4.1.4203.1.10.1", "2.16.840.1.113730.3.4.2", "1.3.6.1.4.1.4203.1.9.1.4", "1.3.6.1.4.1.42.2.27.8.5.1", "1.3.6.1.4.1.4203.1.9.1.1", "1.3.6.1.4.1.4203.1.9.1.3", "1.3.6.1.4.1.4203.1.9.1.2", "1.3.6.1.4.1.18060.0.0.1", "2.16.840.1.113730.3.4.7", "1.2.840.113556.1.4.319") // e.AddAttribute("supportedExtension", "1.3.6.1.4.1.1466.20036", "1.3.6.1.4.1.4203.1.11.1", "1.3.6.1.4.1.18060.0.1.5", "1.3.6.1.4.1.18060.0.1.3", "1.3.6.1.4.1.1466.20037") // e.AddAttribute("supportedSASLMechanisms", "NTLM", "GSSAPI", "GSS-SPNEGO", "CRAM-MD5", "SIMPLE", "DIGEST-MD5") // e.AddAttribute("entryUUID", "f290425c-8272-4e62-8a67-92b06f38dbf5") w.Write(e) res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }
func handleSearchMyCompany(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() log.Printf("handleSearchMyCompany - Request BaseDn=%s", r.BaseObject()) e := ldap.NewSearchResultEntry(string(r.BaseObject())) e.AddAttribute("objectClass", "top", "organizationalUnit") w.Write(e) res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }
func (t *testLDAPServer) handleSearch(w ldapserver.ResponseWriter, m *ldapserver.Message) { r := m.GetSearchRequest() // Record the entry t.SearchRequests = append(t.SearchRequests, r) // Write the results for _, entry := range t.SearchResults { w.Write(entry) } w.Write(ldapserver.NewSearchResultDoneResponse(ldapserver.LDAPResultSuccess)) }