* outposts/ldap: modularise ldap outpost, to allow different searchers and binders Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * outposts/ldap: add basic in-memory searcher Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * providers/ldap: add search mode field Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * outpost: add search mode field Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package direct
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
 | 
						|
	"github.com/nmcclain/ldap"
 | 
						|
	"goauthentik.io/internal/constants"
 | 
						|
	"goauthentik.io/internal/outpost/ldap/search"
 | 
						|
)
 | 
						|
 | 
						|
func (ds *DirectSearcher) SearchBase(req *search.Request, authz bool) (ldap.ServerSearchResult, error) {
 | 
						|
	dn := ""
 | 
						|
	if authz {
 | 
						|
		dn = req.SearchRequest.BaseDN
 | 
						|
	}
 | 
						|
	return ldap.ServerSearchResult{
 | 
						|
		Entries: []*ldap.Entry{
 | 
						|
			{
 | 
						|
				DN: dn,
 | 
						|
				Attributes: []*ldap.EntryAttribute{
 | 
						|
					{
 | 
						|
						Name:   "distinguishedName",
 | 
						|
						Values: []string{ds.si.GetBaseDN()},
 | 
						|
					},
 | 
						|
					{
 | 
						|
						Name:   "objectClass",
 | 
						|
						Values: []string{"top", "domain"},
 | 
						|
					},
 | 
						|
					{
 | 
						|
						Name:   "supportedLDAPVersion",
 | 
						|
						Values: []string{"3"},
 | 
						|
					},
 | 
						|
					{
 | 
						|
						Name: "namingContexts",
 | 
						|
						Values: []string{
 | 
						|
							ds.si.GetBaseDN(),
 | 
						|
							ds.si.GetBaseUserDN(),
 | 
						|
							ds.si.GetBaseGroupDN(),
 | 
						|
						},
 | 
						|
					},
 | 
						|
					{
 | 
						|
						Name:   "vendorName",
 | 
						|
						Values: []string{"goauthentik.io"},
 | 
						|
					},
 | 
						|
					{
 | 
						|
						Name:   "vendorVersion",
 | 
						|
						Values: []string{fmt.Sprintf("authentik LDAP Outpost Version %s (build %s)", constants.VERSION, constants.BUILD())},
 | 
						|
					},
 | 
						|
				},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		Referrals: []string{}, Controls: []ldap.Control{}, ResultCode: ldap.LDAPResultSuccess,
 | 
						|
	}, nil
 | 
						|
}
 |