providers/ldap: rework Schema and DSE (#5838)
* rework Root DSE Signed-off-by: Jens Langhammer <jens@goauthentik.io> * always parse filter objectClass Signed-off-by: Jens Langhammer <jens@goauthentik.io> * start adding LDAP Schema Signed-off-by: Jens Langhammer <jens@goauthentik.io> * add more schema Signed-off-by: Jens Langhammer <jens@goauthentik.io> * update schema more Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix cn for schema Signed-off-by: Jens Langhammer <jens@goauthentik.io> * only include main DN in namingContexts Signed-off-by: Jens Langhammer <jens@goauthentik.io> * use schema from gh Signed-off-by: Jens Langhammer <jens@goauthentik.io> * add description Signed-off-by: Jens Langhammer <jens@goauthentik.io> * add response filtering Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix response filtering Signed-off-by: Jens Langhammer <jens@goauthentik.io> * don't return rootDSE entry when searching for singleLevel Signed-off-by: Jens Langhammer <jens@goauthentik.io> * remove currentTime Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix attribute filtering Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix tests Signed-off-by: Jens Langhammer <jens@goauthentik.io> * set SINGLE-VALUE Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix numbers Signed-off-by: Jens Langhammer <jens@goauthentik.io> --------- Signed-off-by: Jens Langhammer <jens@goauthentik.io>
This commit is contained in:
		| @ -2,16 +2,13 @@ package ldap | ||||
|  | ||||
| import ( | ||||
| 	"crypto/tls" | ||||
| 	"fmt" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
|  | ||||
| 	"beryju.io/ldap" | ||||
| 	"github.com/go-openapi/strfmt" | ||||
| 	log "github.com/sirupsen/logrus" | ||||
|  | ||||
| 	"goauthentik.io/api/v3" | ||||
| 	"goauthentik.io/internal/constants" | ||||
| 	"goauthentik.io/internal/outpost/ldap/bind" | ||||
| 	ldapConstants "goauthentik.io/internal/outpost/ldap/constants" | ||||
| 	"goauthentik.io/internal/outpost/ldap/flags" | ||||
| @ -107,43 +104,6 @@ func (pi *ProviderInstance) GetSearchAllowedGroups() []*strfmt.UUID { | ||||
| 	return pi.searchAllowedGroups | ||||
| } | ||||
|  | ||||
| func (pi *ProviderInstance) GetBaseEntry() *ldap.Entry { | ||||
| 	return &ldap.Entry{ | ||||
| 		DN: pi.GetBaseDN(), | ||||
| 		Attributes: []*ldap.EntryAttribute{ | ||||
| 			{ | ||||
| 				Name:   "distinguishedName", | ||||
| 				Values: []string{pi.GetBaseDN()}, | ||||
| 			}, | ||||
| 			{ | ||||
| 				Name:   "objectClass", | ||||
| 				Values: []string{ldapConstants.OCTop, ldapConstants.OCDomain}, | ||||
| 			}, | ||||
| 			{ | ||||
| 				Name:   "supportedLDAPVersion", | ||||
| 				Values: []string{"3"}, | ||||
| 			}, | ||||
| 			{ | ||||
| 				Name: "namingContexts", | ||||
| 				Values: []string{ | ||||
| 					pi.GetBaseDN(), | ||||
| 					pi.GetBaseUserDN(), | ||||
| 					pi.GetBaseGroupDN(), | ||||
| 					pi.GetBaseVirtualGroupDN(), | ||||
| 				}, | ||||
| 			}, | ||||
| 			{ | ||||
| 				Name:   "vendorName", | ||||
| 				Values: []string{"goauthentik.io"}, | ||||
| 			}, | ||||
| 			{ | ||||
| 				Name:   "vendorVersion", | ||||
| 				Values: []string{fmt.Sprintf("authentik LDAP Outpost Version %s", constants.FullVersion())}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (pi *ProviderInstance) GetNeededObjects(scope int, baseDN string, filterOC string) (bool, bool) { | ||||
| 	needUsers := false | ||||
| 	needGroups := false | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Jens L
					Jens L