| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- package middleware
- import (
- "encoding/json"
- "testing"
- . "github.com/smartystreets/goconvey/convey"
- "github.com/grafana/grafana/pkg/bus"
- authLogin "github.com/grafana/grafana/pkg/login"
- "github.com/grafana/grafana/pkg/models"
- "github.com/grafana/grafana/pkg/setting"
- "github.com/grafana/grafana/pkg/util"
- )
- func TestMiddlewareBasicAuth(t *testing.T) {
- Convey("Given the basic auth", t, func() {
- var oldBasicAuthEnabled = setting.BasicAuthEnabled
- var oldDisableBruteForceLoginProtection = setting.DisableBruteForceLoginProtection
- var id int64 = 12
- Convey("Setup", func() {
- setting.BasicAuthEnabled = true
- setting.DisableBruteForceLoginProtection = true
- bus.ClearBusHandlers()
- })
- middlewareScenario(t, "Valid API key", func(sc *scenarioContext) {
- var orgID int64 = 2
- keyhash := util.EncodePassword("v5nAwpMafFP6znaS4urhdWDLS5511M42", "asd")
- bus.AddHandler("test", func(query *models.GetApiKeyByNameQuery) error {
- query.Result = &models.ApiKey{OrgId: orgID, Role: models.ROLE_EDITOR, Key: keyhash}
- return nil
- })
- authHeader := util.GetBasicAuthHeader("api_key", "eyJrIjoidjVuQXdwTWFmRlA2em5hUzR1cmhkV0RMUzU1MTFNNDIiLCJuIjoiYXNkIiwiaWQiOjF9")
- sc.fakeReq("GET", "/").withAuthorizationHeader(authHeader).exec()
- Convey("Should return 200", func() {
- So(sc.resp.Code, ShouldEqual, 200)
- })
- Convey("Should init middleware context", func() {
- So(sc.context.IsSignedIn, ShouldEqual, true)
- So(sc.context.OrgId, ShouldEqual, orgID)
- So(sc.context.OrgRole, ShouldEqual, models.ROLE_EDITOR)
- })
- })
- middlewareScenario(t, "Handle auth", func(sc *scenarioContext) {
- var password = "MyPass"
- var salt = "Salt"
- var orgID int64 = 2
- bus.AddHandler("grafana-auth", func(query *models.LoginUserQuery) error {
- query.User = &models.User{
- Password: util.EncodePassword(password, salt),
- Salt: salt,
- }
- return nil
- })
- bus.AddHandler("get-sign-user", func(query *models.GetSignedInUserQuery) error {
- query.Result = &models.SignedInUser{OrgId: orgID, UserId: id}
- return nil
- })
- authHeader := util.GetBasicAuthHeader("myUser", password)
- sc.fakeReq("GET", "/").withAuthorizationHeader(authHeader).exec()
- Convey("Should init middleware context with users", func() {
- So(sc.context.IsSignedIn, ShouldEqual, true)
- So(sc.context.OrgId, ShouldEqual, orgID)
- So(sc.context.UserId, ShouldEqual, id)
- })
- bus.ClearBusHandlers()
- })
- middlewareScenario(t, "Auth sequence", func(sc *scenarioContext) {
- var password = "MyPass"
- var salt = "Salt"
- authLogin.Init()
- bus.AddHandler("user-query", func(query *models.GetUserByLoginQuery) error {
- query.Result = &models.User{
- Password: util.EncodePassword(password, salt),
- Id: id,
- Salt: salt,
- }
- return nil
- })
- bus.AddHandler("get-sign-user", func(query *models.GetSignedInUserQuery) error {
- query.Result = &models.SignedInUser{UserId: query.UserId}
- return nil
- })
- authHeader := util.GetBasicAuthHeader("myUser", password)
- sc.fakeReq("GET", "/").withAuthorizationHeader(authHeader).exec()
- Convey("Should init middleware context with user", func() {
- So(sc.context.IsSignedIn, ShouldEqual, true)
- So(sc.context.UserId, ShouldEqual, id)
- })
- })
- middlewareScenario(t, "Should return error if user is not found", func(sc *scenarioContext) {
- sc.fakeReq("GET", "/")
- sc.req.SetBasicAuth("user", "password")
- sc.exec()
- err := json.NewDecoder(sc.resp.Body).Decode(&sc.respJson)
- So(err, ShouldNotBeNil)
- So(sc.resp.Code, ShouldEqual, 401)
- So(sc.respJson["message"], ShouldEqual, errStringInvalidUsernamePassword)
- })
- middlewareScenario(t, "Should return error if user & password do not match", func(sc *scenarioContext) {
- bus.AddHandler("user-query", func(loginUserQuery *models.GetUserByLoginQuery) error {
- return nil
- })
- sc.fakeReq("GET", "/")
- sc.req.SetBasicAuth("killa", "gorilla")
- sc.exec()
- err := json.NewDecoder(sc.resp.Body).Decode(&sc.respJson)
- So(err, ShouldNotBeNil)
- So(sc.resp.Code, ShouldEqual, 401)
- So(sc.respJson["message"], ShouldEqual, errStringInvalidUsernamePassword)
- })
- Convey("Destroy", func() {
- setting.BasicAuthEnabled = oldBasicAuthEnabled
- setting.DisableBruteForceLoginProtection = oldDisableBruteForceLoginProtection
- })
- })
- }
|