mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 01:34:27 +00:00 
			
		
		
		
	@@ -88,6 +88,8 @@ var migrations = []Migration{
 | 
				
			|||||||
	NewMigration("add external login user", addExternalLoginUser),
 | 
						NewMigration("add external login user", addExternalLoginUser),
 | 
				
			||||||
	// v19 -> v20
 | 
						// v19 -> v20
 | 
				
			||||||
	NewMigration("generate and migrate Git hooks", generateAndMigrateGitHooks),
 | 
						NewMigration("generate and migrate Git hooks", generateAndMigrateGitHooks),
 | 
				
			||||||
 | 
						// v20 -> v21
 | 
				
			||||||
 | 
						NewMigration("use new avtar path name for security reason", useNewNameAvatars),
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Migrate database to current version
 | 
					// Migrate database to current version
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										66
									
								
								models/migrations/v20.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								models/migrations/v20.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					// Copyright 2017 The Gitea 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 migrations
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"crypto/md5"
 | 
				
			||||||
 | 
						"errors"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
						"io/ioutil"
 | 
				
			||||||
 | 
						"os"
 | 
				
			||||||
 | 
						"path/filepath"
 | 
				
			||||||
 | 
						"strconv"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"code.gitea.io/gitea/modules/setting"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/go-xorm/xorm"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func useNewNameAvatars(x *xorm.Engine) error {
 | 
				
			||||||
 | 
						d, err := os.Open(setting.AvatarUploadPath)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						names, err := d.Readdirnames(0)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						type User struct {
 | 
				
			||||||
 | 
							Avatar          string
 | 
				
			||||||
 | 
							UseCustomAvatar bool
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, name := range names {
 | 
				
			||||||
 | 
							userID, err := strconv.ParseInt(name, 10, 64)
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								return err
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							var user User
 | 
				
			||||||
 | 
							if has, err := x.ID(userID).Get(&user); err != nil {
 | 
				
			||||||
 | 
								return err
 | 
				
			||||||
 | 
							} else if !has {
 | 
				
			||||||
 | 
								return errors.New("Avatar user is not exist")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							fPath := filepath.Join(setting.AvatarUploadPath, name)
 | 
				
			||||||
 | 
							bs, err := ioutil.ReadFile(fPath)
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								return err
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							user.Avatar = fmt.Sprintf("%x", md5.Sum(bs))
 | 
				
			||||||
 | 
							err = os.Rename(fPath, filepath.Join(setting.AvatarUploadPath, user.Avatar))
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								return err
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							_, err = x.ID(userID).Cols("avatar").Update(&user)
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								return err
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -7,6 +7,7 @@ package models
 | 
				
			|||||||
import (
 | 
					import (
 | 
				
			||||||
	"bytes"
 | 
						"bytes"
 | 
				
			||||||
	"container/list"
 | 
						"container/list"
 | 
				
			||||||
 | 
						"crypto/md5"
 | 
				
			||||||
	"crypto/sha256"
 | 
						"crypto/sha256"
 | 
				
			||||||
	"crypto/subtle"
 | 
						"crypto/subtle"
 | 
				
			||||||
	"encoding/hex"
 | 
						"encoding/hex"
 | 
				
			||||||
@@ -281,7 +282,7 @@ func (u *User) GenerateActivateCode() string {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
// CustomAvatarPath returns user custom avatar file path.
 | 
					// CustomAvatarPath returns user custom avatar file path.
 | 
				
			||||||
func (u *User) CustomAvatarPath() string {
 | 
					func (u *User) CustomAvatarPath() string {
 | 
				
			||||||
	return filepath.Join(setting.AvatarUploadPath, com.ToStr(u.ID))
 | 
						return filepath.Join(setting.AvatarUploadPath, u.Avatar)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// GenerateRandomAvatar generates a random avatar for user.
 | 
					// GenerateRandomAvatar generates a random avatar for user.
 | 
				
			||||||
@@ -326,7 +327,7 @@ func (u *User) RelAvatarLink() string {
 | 
				
			|||||||
		if !com.IsExist(u.CustomAvatarPath()) {
 | 
							if !com.IsExist(u.CustomAvatarPath()) {
 | 
				
			||||||
			return defaultImgURL
 | 
								return defaultImgURL
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		return setting.AppSubURL + "/avatars/" + com.ToStr(u.ID)
 | 
							return setting.AppSubURL + "/avatars/" + u.Avatar
 | 
				
			||||||
	case setting.DisableGravatar, setting.OfflineMode:
 | 
						case setting.DisableGravatar, setting.OfflineMode:
 | 
				
			||||||
		if !com.IsExist(u.CustomAvatarPath()) {
 | 
							if !com.IsExist(u.CustomAvatarPath()) {
 | 
				
			||||||
			if err := u.GenerateRandomAvatar(); err != nil {
 | 
								if err := u.GenerateRandomAvatar(); err != nil {
 | 
				
			||||||
@@ -334,7 +335,7 @@ func (u *User) RelAvatarLink() string {
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		return setting.AppSubURL + "/avatars/" + com.ToStr(u.ID)
 | 
							return setting.AppSubURL + "/avatars/" + u.Avatar
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	return base.AvatarLink(u.AvatarEmail)
 | 
						return base.AvatarLink(u.AvatarEmail)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -425,6 +426,7 @@ func (u *User) UploadAvatar(data []byte) error {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	u.UseCustomAvatar = true
 | 
						u.UseCustomAvatar = true
 | 
				
			||||||
 | 
						u.Avatar = fmt.Sprintf("%x", md5.Sum(data))
 | 
				
			||||||
	if err = updateUser(sess, u); err != nil {
 | 
						if err = updateUser(sess, u); err != nil {
 | 
				
			||||||
		return fmt.Errorf("updateUser: %v", err)
 | 
							return fmt.Errorf("updateUser: %v", err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user