func (d *DefaultsBackend) Search(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() if r.BaseObject() == "" && r.Scope() == ldap.SearchRequestScopeBaseObject && r.FilterString() == "(objectclass=*)" { d.searchDSE(w, m) return } if r.BaseObject() == "o=Pronoc, c=Net" && r.Scope() == ldap.SearchRequestScopeBaseObject { d.searchMyCompany(w, m) } }
func (d *DefaultsBackend) searchMyCompany(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() d.Log.Debug("SearchMyCompany", log.Ctx{"basedn": r.BaseObject(), "filter": r.Filter(), "filterString": r.FilterString(), "attributes": r.Attributes(), "timeLimit": r.TimeLimit().Int()}) e := ldap.NewSearchResultEntry(string(r.BaseObject())) e.AddAttribute("objectClass", "top", "organizationalUnit") w.Write(e) res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }
func (l *LdifBackend) Search(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() // Handle Stop Signal (server stop / client disconnected / Abandoned request....) select { case <-m.Done: l.Log.Debug("Leaving Search... stop signal") return default: } l.Log.Debug("Search", log.Ctx{"basedn": r.BaseObject(), "filter": r.Filter(), "filterString": r.FilterString(), "attributes": r.Attributes(), "timeLimit": r.TimeLimit().Int()}) var entries []message.SearchResultEntry for _, ldif := range l.ldifs { if strings.ToLower(ldif.dn) == strings.ToLower(string(r.BaseObject())) { if m, result := matchesFilter(r.Filter(), ldif); m != true { if result != ldap.LDAPResultSuccess { res := ldap.NewSearchResultDoneResponse(result) w.Write(res) //return make([]message.SearchResultEntry, 0), result return } continue } entry := l.formatEntry(&ldif, r.Attributes()) entries = append(entries, entry) continue } if strings.HasSuffix(strings.ToLower(ldif.dn), strings.ToLower(string(r.BaseObject()))) { if m, result := matchesFilter(r.Filter(), ldif); m != true { if result != ldap.LDAPResultSuccess { res := ldap.NewSearchResultDoneResponse(result) w.Write(res) //return make([]message.SearchResultEntry, 0), result return } continue } entry := l.formatEntry(&ldif, r.Attributes()) entries = append(entries, entry) continue } } for i := 0; i < len(entries); i++ { w.Write(entries[i]) } res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }
func (d *DefaultsBackend) searchDSE(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() d.Log.Debug("SearchDSE", log.Ctx{"basedn": r.BaseObject(), "filter": r.Filter(), "filterString": r.FilterString(), "attributes": r.Attributes(), "timeLimit": r.TimeLimit().Int()}) e := ldap.NewSearchResultEntry("") e.AddAttribute("vendorName", "Jeroen Simonetti") e.AddAttribute("vendorVersion", "0.0.1") e.AddAttribute("objectClass", "top", "extensibleObject") e.AddAttribute("supportedLDAPVersion", "3") e.AddAttribute("namingContexts", "o=Pronoc, c=Net") e.AddAttribute("supportedExtension", "1.3.6.1.4.1.1466.20037") // 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 (d *DebugBackend) Search(w ldap.ResponseWriter, m *ldap.Message) { r := m.GetSearchRequest() dump(r) res := ldap.NewSearchResultDoneResponse(ldap.LDAPResultSuccess) w.Write(res) }