mirror of
https://github.com/grafana/grafana.git
synced 2025-07-29 17:02:20 +08:00
LDAP: finishing touches (#17945)
* LDAP:Docs: `active_sync_enabled` setting Mention `active_sync_enabled` setting and enable it by default * LDAP: move "disableExternalUser" method Idea behind new design of the LDAP module is to minimise conflation between other parts of the system, so it would decoupled as much as possible from stuff like database, HTTP transport and etc. Following "Do One Thing and Do It Well" Unix philosophy principal, other things could be better fitted on the consumer side of things. Which what this commit trying to archive * LDAP: correct user/admin binding The second binding was not happening, so if the admin login/password in LDAP configuration was correct, anyone could had login as anyone using incorrect password
This commit is contained in:
@ -103,10 +103,10 @@ func TestPublicAPI(t *testing.T) {
|
||||
})
|
||||
|
||||
Convey("Auth()", t, func() {
|
||||
Convey("Should ignore passsed username and password", func() {
|
||||
Convey("Should use provided DN and password", func() {
|
||||
connection := &MockConnection{}
|
||||
var actualUsername, actualPassword string
|
||||
connection.bindProvider = func(username, password string) error {
|
||||
connection.BindProvider = func(username, password string) error {
|
||||
actualUsername = username
|
||||
actualPassword = password
|
||||
return nil
|
||||
@ -114,33 +114,15 @@ func TestPublicAPI(t *testing.T) {
|
||||
server := &Server{
|
||||
Connection: connection,
|
||||
Config: &ServerConfig{
|
||||
BindDN: "cn=admin,dc=grafana,dc=org",
|
||||
BindPassword: "bindpwd",
|
||||
BindDN: "cn=admin,dc=grafana,dc=org",
|
||||
},
|
||||
}
|
||||
err := server.Auth("user", "pwd")
|
||||
So(err, ShouldBeNil)
|
||||
So(actualUsername, ShouldEqual, "cn=admin,dc=grafana,dc=org")
|
||||
So(actualPassword, ShouldEqual, "bindpwd")
|
||||
})
|
||||
|
||||
Convey("Given bind dn configured", func() {
|
||||
connection := &MockConnection{}
|
||||
var actualUsername, actualPassword string
|
||||
connection.bindProvider = func(username, password string) error {
|
||||
actualUsername = username
|
||||
actualPassword = password
|
||||
return nil
|
||||
}
|
||||
server := &Server{
|
||||
Connection: connection,
|
||||
Config: &ServerConfig{
|
||||
BindDN: "cn=%s,o=users,dc=grafana,dc=org",
|
||||
},
|
||||
}
|
||||
err := server.Auth("user", "pwd")
|
||||
dn := "cn=user,ou=users,dc=grafana,dc=org"
|
||||
err := server.Auth(dn, "pwd")
|
||||
|
||||
So(err, ShouldBeNil)
|
||||
So(actualUsername, ShouldEqual, "cn=user,o=users,dc=grafana,dc=org")
|
||||
So(actualUsername, ShouldEqual, dn)
|
||||
So(actualPassword, ShouldEqual, "pwd")
|
||||
})
|
||||
|
||||
@ -149,13 +131,13 @@ func TestPublicAPI(t *testing.T) {
|
||||
expected := &ldap.Error{
|
||||
ResultCode: uint16(25),
|
||||
}
|
||||
connection.bindProvider = func(username, password string) error {
|
||||
connection.BindProvider = func(username, password string) error {
|
||||
return expected
|
||||
}
|
||||
server := &Server{
|
||||
Connection: connection,
|
||||
Config: &ServerConfig{
|
||||
BindDN: "cn=%s,o=users,dc=grafana,dc=org",
|
||||
BindDN: "cn=%s,ou=users,dc=grafana,dc=org",
|
||||
},
|
||||
log: log.New("test-logger"),
|
||||
}
|
||||
@ -163,4 +145,56 @@ func TestPublicAPI(t *testing.T) {
|
||||
So(err, ShouldEqual, expected)
|
||||
})
|
||||
})
|
||||
|
||||
Convey("AuthAdmin()", t, func() {
|
||||
Convey("Should use admin DN and password", func() {
|
||||
connection := &MockConnection{}
|
||||
var actualUsername, actualPassword string
|
||||
connection.BindProvider = func(username, password string) error {
|
||||
actualUsername = username
|
||||
actualPassword = password
|
||||
return nil
|
||||
}
|
||||
|
||||
dn := "cn=admin,dc=grafana,dc=org"
|
||||
|
||||
server := &Server{
|
||||
Connection: connection,
|
||||
Config: &ServerConfig{
|
||||
BindPassword: "pwd",
|
||||
BindDN: dn,
|
||||
},
|
||||
}
|
||||
|
||||
err := server.AuthAdmin()
|
||||
|
||||
So(err, ShouldBeNil)
|
||||
So(actualUsername, ShouldEqual, dn)
|
||||
So(actualPassword, ShouldEqual, "pwd")
|
||||
})
|
||||
|
||||
Convey("Should handle an error", func() {
|
||||
connection := &MockConnection{}
|
||||
expected := &ldap.Error{
|
||||
ResultCode: uint16(25),
|
||||
}
|
||||
connection.BindProvider = func(username, password string) error {
|
||||
return expected
|
||||
}
|
||||
|
||||
dn := "cn=admin,dc=grafana,dc=org"
|
||||
|
||||
server := &Server{
|
||||
Connection: connection,
|
||||
Config: &ServerConfig{
|
||||
BindPassword: "pwd",
|
||||
BindDN: dn,
|
||||
},
|
||||
log: log.New("test-logger"),
|
||||
}
|
||||
|
||||
err := server.AuthAdmin()
|
||||
So(err, ShouldEqual, expected)
|
||||
})
|
||||
})
|
||||
}
|
||||
|
Reference in New Issue
Block a user