mirror of
https://github.com/grafana/grafana.git
synced 2025-01-21 14:03:29 -06:00
62b85a886e
* Feature: add cron setting for the ldap settings * Move ldap configuration read to special function * Introduce cron setting (no docs for it yet, pending approval) * Chore: duplicate ldap module as a service * Feature: implement active sync This is very early preliminary implementation of active sync. There is only one thing that's going right for this code - it works. Aside from that, there is no tests, error handling, docs, transactions, it's very much duplicative and etc. But this is the overall direction with architecture I'm going for * Chore: introduce login service * Chore: gradually switch to ldap service * Chore: use new approach for auth_proxy * Chore: use new approach along with refactoring * Chore: use new ldap interface for auth_proxy * Chore: improve auth_proxy and subsequently ldap * Chore: more of the refactoring bits * Chore: address comments from code review * Chore: more refactoring stuff * Chore: make linter happy * Chore: add cron dep for grafana enterprise * Chore: initialize config package var * Chore: disable gosec for now * Chore: update dependencies * Chore: remove unused module * Chore: address review comments * Chore: make linter happy
28 lines
376 B
Go
28 lines
376 B
Go
package ldap
|
|
|
|
import (
|
|
"strings"
|
|
)
|
|
|
|
type UserInfo struct {
|
|
DN string
|
|
FirstName string
|
|
LastName string
|
|
Username string
|
|
Email string
|
|
MemberOf []string
|
|
}
|
|
|
|
func (u *UserInfo) isMemberOf(group string) bool {
|
|
if group == "*" {
|
|
return true
|
|
}
|
|
|
|
for _, member := range u.MemberOf {
|
|
if strings.EqualFold(member, group) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|