| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 | // 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 authimport (	"net/http"	"reflect"	"github.com/go-martini/martini"	"github.com/gogits/session"	"github.com/gogits/gogs/models"	"github.com/gogits/gogs/modules/base"	"github.com/gogits/gogs/modules/log"	"github.com/gogits/gogs/modules/middleware/binding"	"github.com/gogits/gogs/modules/setting")// SignedInId returns the id of signed in user.func SignedInId(header http.Header, sess session.SessionStore) int64 {	if !models.HasEngine {		return 0	}	if setting.Service.EnableReverseProxyAuth {		webAuthUser := header.Get(setting.ReverseProxyAuthUser)		if len(webAuthUser) > 0 {			u, err := models.GetUserByName(webAuthUser)			if err != nil {				if err != models.ErrUserNotExist {					log.Error("auth.user.SignedInId(GetUserByName): %v", err)				}				return 0			}			return u.Id		}	}	uid := sess.Get("userId")	if uid == nil {		return 0	}	if id, ok := uid.(int64); ok {		if _, err := models.GetUserById(id); err != nil {			if err != models.ErrUserNotExist {				log.Error("auth.user.SignedInId(GetUserById): %v", err)			}			return 0		}		return id	}	return 0}// SignedInUser returns the user object of signed user.func SignedInUser(header http.Header, sess session.SessionStore) *models.User {	uid := SignedInId(header, sess)	if uid <= 0 {		return nil	}	u, err := models.GetUserById(uid)	if err != nil {		log.Error("user.SignedInUser: %v", err)		return nil	}	return u}// IsSignedIn check if any user has signed in.func IsSignedIn(header http.Header, sess session.SessionStore) bool {	return SignedInId(header, sess) > 0}type FeedsForm struct {	UserId int64 `form:"userid" binding:"Required"`	Page   int64 `form:"p"`}type UpdateProfileForm struct {	UserName string `form:"username" binding:"Required;AlphaDash;MaxSize(30)"`	FullName string `form:"fullname" binding:"MaxSize(40)"`	Email    string `form:"email" binding:"Required;Email;MaxSize(50)"`	Website  string `form:"website" binding:"Url;MaxSize(50)"`	Location string `form:"location" binding:"MaxSize(50)"`	Avatar   string `form:"avatar" binding:"Required;Email;MaxSize(50)"`}func (f *UpdateProfileForm) Name(field string) string {	names := map[string]string{		"UserName": "Username",		"Email":    "E-mail address",		"Website":  "Website",		"Location": "Location",		"Avatar":   "Gravatar Email",	}	return names[field]}func (f *UpdateProfileForm) Validate(errs *binding.Errors, req *http.Request, ctx martini.Context) {	data := ctx.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)	validate(errs, data, f)}type UpdatePasswdForm struct {	OldPasswd    string `form:"oldpasswd" binding:"Required;MinSize(6);MaxSize(30)"`	NewPasswd    string `form:"newpasswd" binding:"Required;MinSize(6);MaxSize(30)"`	RetypePasswd string `form:"retypepasswd"`}func (f *UpdatePasswdForm) Name(field string) string {	names := map[string]string{		"OldPasswd":    "Old password",		"NewPasswd":    "New password",		"RetypePasswd": "Re-type password",	}	return names[field]}func (f *UpdatePasswdForm) Validate(errs *binding.Errors, req *http.Request, ctx martini.Context) {	data := ctx.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)	validate(errs, data, f)}
 |