|
@@ -17,7 +17,6 @@ func loginUsingLdap(query *AuthenticateUserQuery) error {
|
|
|
return err
|
|
return err
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- log.Info("Host: %v", url.Host)
|
|
|
|
|
conn, err := ldap.Dial("tcp", url.Host)
|
|
conn, err := ldap.Dial("tcp", url.Host)
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
return err
|
|
return err
|
|
@@ -25,10 +24,8 @@ func loginUsingLdap(query *AuthenticateUserQuery) error {
|
|
|
|
|
|
|
|
defer conn.Close()
|
|
defer conn.Close()
|
|
|
|
|
|
|
|
- bindFormat := "cn=%s,dc=grafana,dc=org"
|
|
|
|
|
-
|
|
|
|
|
- nx := fmt.Sprintf(bindFormat, query.Username)
|
|
|
|
|
- err = conn.Bind(nx, query.Password)
|
|
|
|
|
|
|
+ bindPath := fmt.Sprintf(setting.LdapBindPath, query.Username)
|
|
|
|
|
+ err = conn.Bind(bindPath, query.Password)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
if ldapErr, ok := err.(*ldap.Error); ok {
|
|
if ldapErr, ok := err.(*ldap.Error); ok {
|
|
@@ -39,12 +36,31 @@ func loginUsingLdap(query *AuthenticateUserQuery) error {
|
|
|
return err
|
|
return err
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- userQuery := m.GetUserByLoginQuery{LoginOrEmail: "admin"}
|
|
|
|
|
|
|
+ searchReq := ldap.SearchRequest{
|
|
|
|
|
+ BaseDN: "dc=grafana,dc=org",
|
|
|
|
|
+ Scope: ldap.ScopeWholeSubtree,
|
|
|
|
|
+ DerefAliases: ldap.NeverDerefAliases,
|
|
|
|
|
+ Attributes: []string{"cn", "sn", "email"},
|
|
|
|
|
+ Filter: fmt.Sprintf("(cn=%s)", query.Username),
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ result, err := conn.Search(&searchReq)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return err
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ log.Info("Search result: %v, error: %v", result, err)
|
|
|
|
|
+
|
|
|
|
|
+ for _, entry := range result.Entries {
|
|
|
|
|
+ log.Info("cn: %s", entry.Attributes[0].Values[0])
|
|
|
|
|
+ log.Info("email: %s", entry.Attributes[2].Values[0])
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ userQuery := m.GetUserByLoginQuery{LoginOrEmail: query.Username}
|
|
|
err = bus.Dispatch(&userQuery)
|
|
err = bus.Dispatch(&userQuery)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
if err == m.ErrUserNotFound {
|
|
if err == m.ErrUserNotFound {
|
|
|
- return ErrInvalidCredentials
|
|
|
|
|
}
|
|
}
|
|
|
return err
|
|
return err
|
|
|
}
|
|
}
|
|
@@ -53,3 +69,8 @@ func loginUsingLdap(query *AuthenticateUserQuery) error {
|
|
|
|
|
|
|
|
return nil
|
|
return nil
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+func createUserFromLdapInfo() error {
|
|
|
|
|
+ return nil
|
|
|
|
|
+
|
|
|
|
|
+}
|