test.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. package ldap
  2. import (
  3. "context"
  4. "crypto/tls"
  5. . "github.com/smartystreets/goconvey/convey"
  6. "gopkg.in/ldap.v3"
  7. "github.com/grafana/grafana/pkg/bus"
  8. "github.com/grafana/grafana/pkg/models"
  9. "github.com/grafana/grafana/pkg/services/login"
  10. )
  11. type mockConnection struct {
  12. searchResult *ldap.SearchResult
  13. searchCalled bool
  14. searchAttributes []string
  15. addParams *ldap.AddRequest
  16. addCalled bool
  17. delParams *ldap.DelRequest
  18. delCalled bool
  19. bindProvider func(username, password string) error
  20. unauthenticatedBindProvider func(username string) error
  21. }
  22. func (c *mockConnection) Bind(username, password string) error {
  23. if c.bindProvider != nil {
  24. return c.bindProvider(username, password)
  25. }
  26. return nil
  27. }
  28. func (c *mockConnection) UnauthenticatedBind(username string) error {
  29. if c.unauthenticatedBindProvider != nil {
  30. return c.unauthenticatedBindProvider(username)
  31. }
  32. return nil
  33. }
  34. func (c *mockConnection) Close() {}
  35. func (c *mockConnection) setSearchResult(result *ldap.SearchResult) {
  36. c.searchResult = result
  37. }
  38. func (c *mockConnection) Search(sr *ldap.SearchRequest) (*ldap.SearchResult, error) {
  39. c.searchCalled = true
  40. c.searchAttributes = sr.Attributes
  41. return c.searchResult, nil
  42. }
  43. func (c *mockConnection) Add(request *ldap.AddRequest) error {
  44. c.addCalled = true
  45. c.addParams = request
  46. return nil
  47. }
  48. func (c *mockConnection) Del(request *ldap.DelRequest) error {
  49. c.delCalled = true
  50. c.delParams = request
  51. return nil
  52. }
  53. func (c *mockConnection) StartTLS(*tls.Config) error {
  54. return nil
  55. }
  56. func authScenario(desc string, fn scenarioFunc) {
  57. Convey(desc, func() {
  58. defer bus.ClearBusHandlers()
  59. sc := &scenarioContext{
  60. loginUserQuery: &models.LoginUserQuery{
  61. Username: "user",
  62. Password: "pwd",
  63. IpAddress: "192.168.1.1:56433",
  64. },
  65. }
  66. loginService := &login.LoginService{
  67. Bus: bus.GetBus(),
  68. }
  69. bus.AddHandler("test", loginService.UpsertUser)
  70. bus.AddHandlerCtx("test", func(ctx context.Context, cmd *models.SyncTeamsCommand) error {
  71. return nil
  72. })
  73. bus.AddHandlerCtx("test", func(ctx context.Context, cmd *models.UpdateUserPermissionsCommand) error {
  74. sc.updateUserPermissionsCmd = cmd
  75. return nil
  76. })
  77. bus.AddHandler("test", func(cmd *models.GetUserByAuthInfoQuery) error {
  78. sc.getUserByAuthInfoQuery = cmd
  79. sc.getUserByAuthInfoQuery.Result = &models.User{Login: cmd.Login}
  80. return nil
  81. })
  82. bus.AddHandler("test", func(cmd *models.GetUserOrgListQuery) error {
  83. sc.getUserOrgListQuery = cmd
  84. return nil
  85. })
  86. bus.AddHandler("test", func(cmd *models.CreateUserCommand) error {
  87. sc.createUserCmd = cmd
  88. sc.createUserCmd.Result = models.User{Login: cmd.Login}
  89. return nil
  90. })
  91. bus.AddHandler("test", func(cmd *models.GetExternalUserInfoByLoginQuery) error {
  92. sc.getExternalUserInfoByLoginQuery = cmd
  93. sc.getExternalUserInfoByLoginQuery.Result = &models.ExternalUserInfo{UserId: 42, IsDisabled: false}
  94. return nil
  95. })
  96. bus.AddHandler("test", func(cmd *models.DisableUserCommand) error {
  97. sc.disableExternalUserCalled = true
  98. sc.disableUserCmd = cmd
  99. return nil
  100. })
  101. bus.AddHandler("test", func(cmd *models.AddOrgUserCommand) error {
  102. sc.addOrgUserCmd = cmd
  103. return nil
  104. })
  105. bus.AddHandler("test", func(cmd *models.UpdateOrgUserCommand) error {
  106. sc.updateOrgUserCmd = cmd
  107. return nil
  108. })
  109. bus.AddHandler("test", func(cmd *models.RemoveOrgUserCommand) error {
  110. sc.removeOrgUserCmd = cmd
  111. return nil
  112. })
  113. bus.AddHandler("test", func(cmd *models.UpdateUserCommand) error {
  114. sc.updateUserCmd = cmd
  115. return nil
  116. })
  117. bus.AddHandler("test", func(cmd *models.SetUsingOrgCommand) error {
  118. sc.setUsingOrgCmd = cmd
  119. return nil
  120. })
  121. fn(sc)
  122. })
  123. }
  124. type scenarioContext struct {
  125. loginUserQuery *models.LoginUserQuery
  126. getUserByAuthInfoQuery *models.GetUserByAuthInfoQuery
  127. getExternalUserInfoByLoginQuery *models.GetExternalUserInfoByLoginQuery
  128. getUserOrgListQuery *models.GetUserOrgListQuery
  129. createUserCmd *models.CreateUserCommand
  130. disableUserCmd *models.DisableUserCommand
  131. addOrgUserCmd *models.AddOrgUserCommand
  132. updateOrgUserCmd *models.UpdateOrgUserCommand
  133. removeOrgUserCmd *models.RemoveOrgUserCommand
  134. updateUserCmd *models.UpdateUserCommand
  135. setUsingOrgCmd *models.SetUsingOrgCommand
  136. updateUserPermissionsCmd *models.UpdateUserPermissionsCommand
  137. disableExternalUserCalled bool
  138. }
  139. func (sc *scenarioContext) userQueryReturns(user *models.User) {
  140. bus.AddHandler("test", func(query *models.GetUserByAuthInfoQuery) error {
  141. if user == nil {
  142. return models.ErrUserNotFound
  143. }
  144. query.Result = user
  145. return nil
  146. })
  147. bus.AddHandler("test", func(query *models.SetAuthInfoCommand) error {
  148. return nil
  149. })
  150. }
  151. func (sc *scenarioContext) userOrgsQueryReturns(orgs []*models.UserOrgDTO) {
  152. bus.AddHandler("test", func(query *models.GetUserOrgListQuery) error {
  153. query.Result = orgs
  154. return nil
  155. })
  156. }
  157. func (sc *scenarioContext) getExternalUserInfoByLoginQueryReturns(externalUser *models.ExternalUserInfo) {
  158. bus.AddHandler("test", func(cmd *models.GetExternalUserInfoByLoginQuery) error {
  159. sc.getExternalUserInfoByLoginQuery = cmd
  160. sc.getExternalUserInfoByLoginQuery.Result = &models.ExternalUserInfo{
  161. UserId: externalUser.UserId,
  162. IsDisabled: externalUser.IsDisabled,
  163. }
  164. return nil
  165. })
  166. }
  167. type scenarioFunc func(c *scenarioContext)