mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Finish register user
This commit is contained in:
		
							
								
								
									
										2
									
								
								gogs.go
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								gogs.go
									
									
									
									
									
								
							@@ -17,7 +17,7 @@ import (
 | 
				
			|||||||
	"github.com/gogits/gogs/utils/log"
 | 
						"github.com/gogits/gogs/utils/log"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const APP_VER = "0.0.0.0217"
 | 
					const APP_VER = "0.0.0.0218"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func init() {
 | 
					func init() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,6 +11,8 @@ import (
 | 
				
			|||||||
	"time"
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/dchest/scrypt"
 | 
						"github.com/dchest/scrypt"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/gogits/gogs/utils"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// User types.
 | 
					// User types.
 | 
				
			||||||
@@ -29,9 +31,9 @@ const (
 | 
				
			|||||||
type User struct {
 | 
					type User struct {
 | 
				
			||||||
	Id            int64
 | 
						Id            int64
 | 
				
			||||||
	LowerName     string `xorm:"unique not null"`
 | 
						LowerName     string `xorm:"unique not null"`
 | 
				
			||||||
	Name          string `xorm:"unique not null"`
 | 
						Name          string `xorm:"unique not null" valid:"Required"`
 | 
				
			||||||
	Email         string `xorm:"unique not null"`
 | 
						Email         string `xorm:"unique not null" valid:"Email"`
 | 
				
			||||||
	Passwd        string `xorm:"not null"`
 | 
						Passwd        string `xorm:"not null" valid:"MinSize(8)"`
 | 
				
			||||||
	LoginType     int
 | 
						LoginType     int
 | 
				
			||||||
	Type          int
 | 
						Type          int
 | 
				
			||||||
	NumFollowers  int
 | 
						NumFollowers  int
 | 
				
			||||||
@@ -82,24 +84,17 @@ func IsUserExist(name string) (bool, error) {
 | 
				
			|||||||
	return orm.Get(&User{LowerName: strings.ToLower(name)})
 | 
						return orm.Get(&User{LowerName: strings.ToLower(name)})
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// validateUser checks if user exist.
 | 
					// RegisterUser creates record of a new user.
 | 
				
			||||||
func validateUser(name string) error {
 | 
					func RegisterUser(user *User) (err error) {
 | 
				
			||||||
	isExist, err := IsUserExist(name)
 | 
						isExist, err := IsUserExist(user.Name)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
	} else if isExist {
 | 
						} else if isExist {
 | 
				
			||||||
		return ErrUserAlreadyExist
 | 
							return ErrUserAlreadyExist
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	return nil
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
// RegisterUser creates record of a new user.
 | 
					 | 
				
			||||||
func RegisterUser(user *User) (err error) {
 | 
					 | 
				
			||||||
	if err = validateUser(user.Name); err != nil {
 | 
					 | 
				
			||||||
		return err
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	user.LowerName = strings.ToLower(user.Name)
 | 
						user.LowerName = strings.ToLower(user.Name)
 | 
				
			||||||
	// TODO: generate Avatar address.
 | 
						user.Avatar = utils.EncodeMd5(user.Email)
 | 
				
			||||||
	user.Created = time.Now()
 | 
						user.Created = time.Now()
 | 
				
			||||||
	user.Updated = time.Now()
 | 
						user.Updated = time.Now()
 | 
				
			||||||
	_, err = orm.Insert(user)
 | 
						_, err = orm.Insert(user)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -10,8 +10,10 @@ import (
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	"github.com/martini-contrib/render"
 | 
						"github.com/martini-contrib/render"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	//"github.com/gogits/gogs/utils/log"
 | 
						"github.com/gogits/validation"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/gogits/gogs/models"
 | 
						"github.com/gogits/gogs/models"
 | 
				
			||||||
 | 
						"github.com/gogits/gogs/utils/log"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func SignIn(r render.Render) {
 | 
					func SignIn(r render.Render) {
 | 
				
			||||||
@@ -26,12 +28,25 @@ func SignUp(req *http.Request, r render.Render) {
 | 
				
			|||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// TODO: validate form.
 | 
						u := &models.User{
 | 
				
			||||||
	err := models.RegisterUser(&models.User{
 | 
					 | 
				
			||||||
		Name:   req.FormValue("username"),
 | 
							Name:   req.FormValue("username"),
 | 
				
			||||||
		Email:  req.FormValue("email"),
 | 
							Email:  req.FormValue("email"),
 | 
				
			||||||
		Passwd: req.FormValue("passwd"),
 | 
							Passwd: req.FormValue("passwd"),
 | 
				
			||||||
	})
 | 
						}
 | 
				
			||||||
 | 
						valid := validation.Validation{}
 | 
				
			||||||
 | 
						ok, err := valid.Valid(u)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							log.Error("user.SignUp -> valid user: %v", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if !ok {
 | 
				
			||||||
 | 
							for _, err := range valid.Errors {
 | 
				
			||||||
 | 
								log.Warn("user.SignUp -> valid user: %v", err)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						err = models.RegisterUser(u)
 | 
				
			||||||
	r.HTML(403, "status/403", map[string]interface{}{
 | 
						r.HTML(403, "status/403", map[string]interface{}{
 | 
				
			||||||
		"Title": fmt.Sprintf("%v", err),
 | 
							"Title": fmt.Sprintf("%v", err),
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,3 +19,11 @@ func init() {
 | 
				
			|||||||
func Info(format string, v ...interface{}) {
 | 
					func Info(format string, v ...interface{}) {
 | 
				
			||||||
	logger.Info(format, v...)
 | 
						logger.Info(format, v...)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func Error(format string, v ...interface{}) {
 | 
				
			||||||
 | 
						logger.Error(format, v...)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func Warn(format string, v ...interface{}) {
 | 
				
			||||||
 | 
						logger.Warn(format, v...)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										17
									
								
								utils/tool.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								utils/tool.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,17 @@
 | 
				
			|||||||
 | 
					// 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 utils
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"crypto/md5"
 | 
				
			||||||
 | 
						"encoding/hex"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Encode string to md5 hex value
 | 
				
			||||||
 | 
					func EncodeMd5(str string) string {
 | 
				
			||||||
 | 
						m := md5.New()
 | 
				
			||||||
 | 
						m.Write([]byte(str))
 | 
				
			||||||
 | 
						return hex.EncodeToString(m.Sum(nil))
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user