Skip to content

Commit 80f900e

Browse files
authored
Fix avatar enumable (#1049)
* fix avatar enumable * fix import style
1 parent 19b3c45 commit 80f900e

File tree

3 files changed

+73
-3
lines changed

3 files changed

+73
-3
lines changed

models/migrations/migrations.go

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -88,6 +88,8 @@ var migrations = []Migration{
8888
NewMigration("add external login user", addExternalLoginUser),
8989
// v19 -> v20
9090
NewMigration("generate and migrate Git hooks", generateAndMigrateGitHooks),
91+
// v20 -> v21
92+
NewMigration("use new avtar path name for security reason", useNewNameAvatars),
9193
}
9294

9395
// Migrate database to current version

models/migrations/v20.go

Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
// Copyright 2017 The Gitea Authors. All rights reserved.
2+
// Use of this source code is governed by a MIT-style
3+
// license that can be found in the LICENSE file.
4+
5+
package migrations
6+
7+
import (
8+
"crypto/md5"
9+
"errors"
10+
"fmt"
11+
"io/ioutil"
12+
"os"
13+
"path/filepath"
14+
"strconv"
15+
16+
"code.gitea.io/gitea/modules/setting"
17+
18+
"github.com/go-xorm/xorm"
19+
)
20+
21+
func useNewNameAvatars(x *xorm.Engine) error {
22+
d, err := os.Open(setting.AvatarUploadPath)
23+
if err != nil {
24+
return err
25+
}
26+
names, err := d.Readdirnames(0)
27+
if err != nil {
28+
return err
29+
}
30+
31+
type User struct {
32+
Avatar string
33+
UseCustomAvatar bool
34+
}
35+
36+
for _, name := range names {
37+
userID, err := strconv.ParseInt(name, 10, 64)
38+
if err != nil {
39+
return err
40+
}
41+
42+
var user User
43+
if has, err := x.ID(userID).Get(&user); err != nil {
44+
return err
45+
} else if !has {
46+
return errors.New("Avatar user is not exist")
47+
}
48+
49+
fPath := filepath.Join(setting.AvatarUploadPath, name)
50+
bs, err := ioutil.ReadFile(fPath)
51+
if err != nil {
52+
return err
53+
}
54+
55+
user.Avatar = fmt.Sprintf("%x", md5.Sum(bs))
56+
err = os.Rename(fPath, filepath.Join(setting.AvatarUploadPath, user.Avatar))
57+
if err != nil {
58+
return err
59+
}
60+
_, err = x.ID(userID).Cols("avatar").Update(&user)
61+
if err != nil {
62+
return err
63+
}
64+
}
65+
return nil
66+
}

models/user.go

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@ package models
77
import (
88
"bytes"
99
"container/list"
10+
"crypto/md5"
1011
"crypto/sha256"
1112
"crypto/subtle"
1213
"encoding/hex"
@@ -281,7 +282,7 @@ func (u *User) GenerateActivateCode() string {
281282

282283
// CustomAvatarPath returns user custom avatar file path.
283284
func (u *User) CustomAvatarPath() string {
284-
return filepath.Join(setting.AvatarUploadPath, com.ToStr(u.ID))
285+
return filepath.Join(setting.AvatarUploadPath, u.Avatar)
285286
}
286287

287288
// GenerateRandomAvatar generates a random avatar for user.
@@ -326,15 +327,15 @@ func (u *User) RelAvatarLink() string {
326327
if !com.IsExist(u.CustomAvatarPath()) {
327328
return defaultImgURL
328329
}
329-
return setting.AppSubURL + "/avatars/" + com.ToStr(u.ID)
330+
return setting.AppSubURL + "/avatars/" + u.Avatar
330331
case setting.DisableGravatar, setting.OfflineMode:
331332
if !com.IsExist(u.CustomAvatarPath()) {
332333
if err := u.GenerateRandomAvatar(); err != nil {
333334
log.Error(3, "GenerateRandomAvatar: %v", err)
334335
}
335336
}
336337

337-
return setting.AppSubURL + "/avatars/" + com.ToStr(u.ID)
338+
return setting.AppSubURL + "/avatars/" + u.Avatar
338339
}
339340
return base.AvatarLink(u.AvatarEmail)
340341
}
@@ -425,6 +426,7 @@ func (u *User) UploadAvatar(data []byte) error {
425426
}
426427

427428
u.UseCustomAvatar = true
429+
u.Avatar = fmt.Sprintf("%x", md5.Sum(data))
428430
if err = updateUser(sess, u); err != nil {
429431
return fmt.Errorf("updateUser: %v", err)
430432
}

0 commit comments

Comments
 (0)