aboutsummaryrefslogtreecommitdiff
path: root/admin.go
diff options
context:
space:
mode:
authorAlex Auvolat <alex@adnab.me>2023-02-08 11:58:46 +0100
committerAlex Auvolat <alex@adnab.me>2023-02-08 11:58:46 +0100
commitcd415325729fddea26c816291bb33171b9cc4879 (patch)
treeb47c3b255d1e9293033d238002c5a6ab1256b1bf /admin.go
parentca41c481b189092843cfb8c4382501037131a69a (diff)
downloadguichet-cd415325729fddea26c816291bb33171b9cc4879.tar.gz
guichet-cd415325729fddea26c816291bb33171b9cc4879.zip
Slight improvements to admin view
Diffstat (limited to 'admin.go')
-rw-r--r--admin.go20
1 files changed, 14 insertions, 6 deletions
diff --git a/admin.go b/admin.go
index 16c3b85..832a815 100644
--- a/admin.go
+++ b/admin.go
@@ -121,7 +121,8 @@ type AdminLDAPTplData struct {
DN string
Path []PathItem
- Children []Child
+ ChildrenOU []Child
+ ChildrenOther []Child
CanAddChild bool
Props map[string]*PropValues
CanDelete bool
@@ -499,17 +500,23 @@ func handleAdminLDAP(w http.ResponseWriter, r *http.Request) {
sort.Sort(EntryList(sr.Entries))
- children := []Child{}
+ childrenOU := []Child{}
+ childrenOther := []Child{}
for _, item := range sr.Entries {
name := item.GetAttributeValue("displayname")
if name == "" {
name = item.GetAttributeValue("description")
}
- children = append(children, Child{
+ child := Child{
DN: item.DN,
Identifier: strings.Split(item.DN, ",")[0],
Name: name,
- })
+ }
+ if strings.HasPrefix(item.DN, "ou=") {
+ childrenOU = append(childrenOU, child)
+ } else {
+ childrenOther = append(childrenOther, child)
+ }
}
// Run template, finally!
@@ -517,10 +524,11 @@ func handleAdminLDAP(w http.ResponseWriter, r *http.Request) {
DN: dn,
Path: path,
- Children: children,
+ ChildrenOU: childrenOU,
+ ChildrenOther: childrenOther,
Props: props,
CanAddChild: dn_last_attr == "ou" || isOrganization,
- CanDelete: dn != config.BaseDN && len(children) == 0,
+ CanDelete: dn != config.BaseDN && len(childrenOU) == 0 && len(childrenOther) == 0,
HasMembers: len(members) > 0 || hasMembers,
Members: members,