mirror of https://github.com/gogits/gogs.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
4.1 KiB
188 lines
4.1 KiB
// Copyright 2014 The Gogs Authors. All rights reserved. |
|
// Use of this source code is governed by a MIT-style |
|
// license that can be found in the LICENSE file. |
|
|
|
package user |
|
|
|
import ( |
|
"fmt" |
|
"net/http" |
|
|
|
//"github.com/martini-contrib/binding" |
|
"github.com/martini-contrib/render" |
|
"github.com/martini-contrib/sessions" |
|
|
|
"github.com/gogits/gogs/models" |
|
"github.com/gogits/gogs/modules/auth" |
|
"github.com/gogits/gogs/modules/base" |
|
"github.com/gogits/gogs/utils/log" |
|
) |
|
|
|
func Dashboard(r render.Render, data base.TmplData, session sessions.Session) { |
|
if !IsSignedIn(session) { |
|
// todo : direct to logout |
|
r.Redirect("/") |
|
return |
|
} |
|
data["IsSigned"] = true |
|
data["SignedUserId"] = SignedInId(session) |
|
data["SignedUserName"] = SignedInName(session) |
|
data["PageIsUserDashboard"] = true |
|
|
|
data["Title"] = "Dashboard" |
|
r.HTML(200, "user/dashboard", data) |
|
} |
|
|
|
func Profile(r render.Render) { |
|
r.HTML(200, "user/profile", map[string]interface{}{ |
|
"Title": "Username", |
|
}) |
|
return |
|
} |
|
|
|
func IsSignedIn(session sessions.Session) bool { |
|
return SignedInId(session) > 0 |
|
} |
|
|
|
func SignedInId(session sessions.Session) int64 { |
|
userId := session.Get("userId") |
|
if userId == nil { |
|
return 0 |
|
} |
|
if s, ok := userId.(int64); ok { |
|
return s |
|
} |
|
return 0 |
|
} |
|
|
|
func SignedInName(session sessions.Session) string { |
|
userName := session.Get("userName") |
|
if userName == nil { |
|
return "" |
|
} |
|
if s, ok := userName.(string); ok { |
|
return s |
|
} |
|
return "" |
|
} |
|
|
|
func SignedInUser(session sessions.Session) *models.User { |
|
id := SignedInId(session) |
|
if id <= 0 { |
|
return nil |
|
} |
|
|
|
user, err := models.GetUserById(id) |
|
if err != nil { |
|
return nil |
|
} |
|
return user |
|
} |
|
|
|
func SignIn(form auth.LogInForm, data base.TmplData, req *http.Request, r render.Render, session sessions.Session) { |
|
// if logged, do not show login page |
|
if IsSignedIn(session) { |
|
r.Redirect("/") |
|
return |
|
} |
|
|
|
data["Title"] = "Log In" |
|
|
|
if req.Method == "GET" { |
|
r.HTML(200, "user/signin", data) |
|
return |
|
} |
|
|
|
if hasErr, ok := data["HasError"]; ok && hasErr.(bool) { |
|
r.HTML(200, "user/signin", data) |
|
return |
|
} |
|
|
|
user, err := models.LoginUserPlain(form.UserName, form.Password) |
|
if err != nil { |
|
if err.Error() == models.ErrUserNotExist.Error() { |
|
data["HasError"] = true |
|
data["ErrorMsg"] = "Username or password is not correct" |
|
auth.AssignForm(form, data) |
|
r.HTML(200, "user/signin", data) |
|
return |
|
} |
|
|
|
data["ErrorMsg"] = err |
|
log.Error("user.SignIn: %v", data) |
|
r.HTML(500, "base/error", nil) |
|
return |
|
} |
|
|
|
// login success |
|
session.Set("userId", user.Id) |
|
session.Set("userName", user.Name) |
|
r.Redirect("/") |
|
} |
|
|
|
func SignUp(form auth.RegisterForm, data base.TmplData, req *http.Request, r render.Render) { |
|
data["Title"] = "Sign Up" |
|
data["PageIsSignUp"] = true |
|
|
|
if req.Method == "GET" { |
|
r.HTML(200, "user/signup", data) |
|
return |
|
} |
|
|
|
if form.Password != form.RetypePasswd { |
|
data["HasError"] = true |
|
data["Err_Password"] = true |
|
data["Err_RetypePasswd"] = true |
|
data["ErrorMsg"] = "Password and re-type password are not same" |
|
auth.AssignForm(form, data) |
|
} |
|
|
|
if hasErr, ok := data["HasError"]; ok && hasErr.(bool) { |
|
r.HTML(200, "user/signup", data) |
|
return |
|
} |
|
|
|
u := &models.User{ |
|
Name: form.UserName, |
|
Email: form.Email, |
|
Passwd: form.Password, |
|
} |
|
|
|
if err := models.RegisterUser(u); err != nil { |
|
data["HasError"] = true |
|
auth.AssignForm(form, data) |
|
|
|
switch err.Error() { |
|
case models.ErrUserAlreadyExist.Error(): |
|
data["Err_Username"] = true |
|
data["ErrorMsg"] = "Username has been already taken" |
|
r.HTML(200, "user/signup", data) |
|
case models.ErrEmailAlreadyUsed.Error(): |
|
data["Err_Email"] = true |
|
data["ErrorMsg"] = "E-mail address has been already used" |
|
r.HTML(200, "user/signup", data) |
|
default: |
|
data["ErrorMsg"] = err |
|
log.Error("user.SignUp: %v", data) |
|
r.HTML(500, "base/error", nil) |
|
} |
|
return |
|
} |
|
|
|
r.Redirect("/user/login") |
|
} |
|
|
|
func Delete(req *http.Request, r render.Render) { |
|
if req.Method == "GET" { |
|
r.HTML(200, "user/delete", map[string]interface{}{ |
|
"Title": "Delete user", |
|
}) |
|
return |
|
} |
|
|
|
u := &models.User{} |
|
err := models.DeleteUser(u) |
|
r.HTML(403, "status/403", map[string]interface{}{ |
|
"Title": fmt.Sprintf("%v", err), |
|
}) |
|
}
|
|
|