| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- package api
- import (
- "net/url"
- "github.com/grafana/grafana/pkg/api/dtos"
- "github.com/grafana/grafana/pkg/bus"
- "github.com/grafana/grafana/pkg/log"
- "github.com/grafana/grafana/pkg/login"
- "github.com/grafana/grafana/pkg/metrics"
- "github.com/grafana/grafana/pkg/middleware"
- m "github.com/grafana/grafana/pkg/models"
- "github.com/grafana/grafana/pkg/setting"
- )
- const (
- VIEW_INDEX = "index"
- )
- func LoginView(c *middleware.Context) {
- viewData, err := setIndexViewData(c)
- if err != nil {
- c.Handle(500, "Failed to get settings", err)
- return
- }
- enabledOAuths := make(map[string]interface{})
- for key, oauth := range setting.OAuthService.OAuthInfos {
- enabledOAuths[key] = map[string]string{"name": oauth.Name}
- }
- viewData.Settings["oauth"] = enabledOAuths
- viewData.Settings["disableUserSignUp"] = !setting.AllowUserSignUp
- viewData.Settings["loginHint"] = setting.LoginHint
- viewData.Settings["disableLoginForm"] = setting.DisableLoginForm
- if loginError, ok := c.Session.Get("loginError").(string); ok {
- c.Session.Delete("loginError")
- viewData.Settings["loginError"] = loginError
- }
- if !tryLoginUsingRememberCookie(c) {
- c.HTML(200, VIEW_INDEX, viewData)
- return
- }
- if redirectTo, _ := url.QueryUnescape(c.GetCookie("redirect_to")); len(redirectTo) > 0 {
- c.SetCookie("redirect_to", "", -1, setting.AppSubUrl+"/")
- c.Redirect(redirectTo)
- return
- }
- c.Redirect(setting.AppSubUrl + "/")
- }
- func tryLoginUsingRememberCookie(c *middleware.Context) bool {
- // Check auto-login.
- uname := c.GetCookie(setting.CookieUserName)
- if len(uname) == 0 {
- return false
- }
- isSucceed := false
- defer func() {
- if !isSucceed {
- log.Trace("auto-login cookie cleared: %s", uname)
- c.SetCookie(setting.CookieUserName, "", -1, setting.AppSubUrl+"/")
- c.SetCookie(setting.CookieRememberName, "", -1, setting.AppSubUrl+"/")
- return
- }
- }()
- userQuery := m.GetUserByLoginQuery{LoginOrEmail: uname}
- if err := bus.Dispatch(&userQuery); err != nil {
- return false
- }
- user := userQuery.Result
- // validate remember me cookie
- if val, _ := c.GetSuperSecureCookie(user.Rands+user.Password, setting.CookieRememberName); val != user.Login {
- return false
- }
- isSucceed = true
- loginUserWithUser(user, c)
- return true
- }
- func LoginApiPing(c *middleware.Context) {
- if !tryLoginUsingRememberCookie(c) {
- c.JsonApiErr(401, "Unauthorized", nil)
- return
- }
- c.JsonOK("Logged in")
- }
- func LoginPost(c *middleware.Context, cmd dtos.LoginCommand) Response {
- if setting.DisableLoginForm {
- return ApiError(401, "Login is disabled", nil)
- }
- authQuery := login.LoginUserQuery{
- Username: cmd.User,
- Password: cmd.Password,
- }
- if err := bus.Dispatch(&authQuery); err != nil {
- if err == login.ErrInvalidCredentials {
- return ApiError(401, "Invalid username or password", err)
- }
- return ApiError(500, "Error while trying to authenticate user", err)
- }
- user := authQuery.User
- loginUserWithUser(user, c)
- result := map[string]interface{}{
- "message": "Logged in",
- }
- if redirectTo, _ := url.QueryUnescape(c.GetCookie("redirect_to")); len(redirectTo) > 0 {
- result["redirectUrl"] = redirectTo
- c.SetCookie("redirect_to", "", -1, setting.AppSubUrl+"/")
- }
- metrics.M_Api_Login_Post.Inc()
- return Json(200, result)
- }
- func loginUserWithUser(user *m.User, c *middleware.Context) {
- if user == nil {
- log.Error(3, "User login with nil user")
- }
- c.Resp.Header().Del("Set-Cookie")
- days := 86400 * setting.LogInRememberDays
- if days > 0 {
- c.SetCookie(setting.CookieUserName, user.Login, days, setting.AppSubUrl+"/")
- c.SetSuperSecureCookie(user.Rands+user.Password, setting.CookieRememberName, user.Login, days, setting.AppSubUrl+"/")
- }
- c.Session.RegenerateId(c)
- c.Session.Set(middleware.SESS_KEY_USERID, user.Id)
- }
- func Logout(c *middleware.Context) {
- c.SetCookie(setting.CookieUserName, "", -1, setting.AppSubUrl+"/")
- c.SetCookie(setting.CookieRememberName, "", -1, setting.AppSubUrl+"/")
- c.Session.Destory(c)
- c.Redirect(setting.AppSubUrl + "/login")
- }
|