mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 08:02:36 +09:00 
			
		
		
		
	Fix bug on avatar (#31008)
Co-authored-by: silverwind <me@silverwind.io>
This commit is contained in:
		@@ -46,6 +46,7 @@ func UpdateAvatar(ctx *context.APIContext) {
 | 
				
			|||||||
	err = user_service.UploadAvatar(ctx, ctx.Org.Organization.AsUser(), content)
 | 
						err = user_service.UploadAvatar(ctx, ctx.Org.Organization.AsUser(), content)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		ctx.Error(http.StatusInternalServerError, "UploadAvatar", err)
 | 
							ctx.Error(http.StatusInternalServerError, "UploadAvatar", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx.Status(http.StatusNoContent)
 | 
						ctx.Status(http.StatusNoContent)
 | 
				
			||||||
@@ -72,6 +73,7 @@ func DeleteAvatar(ctx *context.APIContext) {
 | 
				
			|||||||
	err := user_service.DeleteAvatar(ctx, ctx.Org.Organization.AsUser())
 | 
						err := user_service.DeleteAvatar(ctx, ctx.Org.Organization.AsUser())
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		ctx.Error(http.StatusInternalServerError, "DeleteAvatar", err)
 | 
							ctx.Error(http.StatusInternalServerError, "DeleteAvatar", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx.Status(http.StatusNoContent)
 | 
						ctx.Status(http.StatusNoContent)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -39,6 +39,7 @@ func UpdateAvatar(ctx *context.APIContext) {
 | 
				
			|||||||
	err = user_service.UploadAvatar(ctx, ctx.Doer, content)
 | 
						err = user_service.UploadAvatar(ctx, ctx.Doer, content)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		ctx.Error(http.StatusInternalServerError, "UploadAvatar", err)
 | 
							ctx.Error(http.StatusInternalServerError, "UploadAvatar", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx.Status(http.StatusNoContent)
 | 
						ctx.Status(http.StatusNoContent)
 | 
				
			||||||
@@ -57,6 +58,7 @@ func DeleteAvatar(ctx *context.APIContext) {
 | 
				
			|||||||
	err := user_service.DeleteAvatar(ctx, ctx.Doer)
 | 
						err := user_service.DeleteAvatar(ctx, ctx.Doer)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		ctx.Error(http.StatusInternalServerError, "DeleteAvatar", err)
 | 
							ctx.Error(http.StatusInternalServerError, "DeleteAvatar", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx.Status(http.StatusNoContent)
 | 
						ctx.Status(http.StatusNoContent)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,8 +5,10 @@ package user
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"context"
 | 
						"context"
 | 
				
			||||||
 | 
						"errors"
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
	"io"
 | 
						"io"
 | 
				
			||||||
 | 
						"os"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"code.gitea.io/gitea/models/db"
 | 
						"code.gitea.io/gitea/models/db"
 | 
				
			||||||
	user_model "code.gitea.io/gitea/models/user"
 | 
						user_model "code.gitea.io/gitea/models/user"
 | 
				
			||||||
@@ -48,16 +50,24 @@ func UploadAvatar(ctx context.Context, u *user_model.User, data []byte) error {
 | 
				
			|||||||
func DeleteAvatar(ctx context.Context, u *user_model.User) error {
 | 
					func DeleteAvatar(ctx context.Context, u *user_model.User) error {
 | 
				
			||||||
	aPath := u.CustomAvatarRelativePath()
 | 
						aPath := u.CustomAvatarRelativePath()
 | 
				
			||||||
	log.Trace("DeleteAvatar[%d]: %s", u.ID, aPath)
 | 
						log.Trace("DeleteAvatar[%d]: %s", u.ID, aPath)
 | 
				
			||||||
	if len(u.Avatar) > 0 {
 | 
					 | 
				
			||||||
		if err := storage.Avatars.Delete(aPath); err != nil {
 | 
					 | 
				
			||||||
			return fmt.Errorf("Failed to remove %s: %w", aPath, err)
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return db.WithTx(ctx, func(ctx context.Context) error {
 | 
				
			||||||
 | 
							hasAvatar := len(u.Avatar) > 0
 | 
				
			||||||
		u.UseCustomAvatar = false
 | 
							u.UseCustomAvatar = false
 | 
				
			||||||
		u.Avatar = ""
 | 
							u.Avatar = ""
 | 
				
			||||||
		if _, err := db.GetEngine(ctx).ID(u.ID).Cols("avatar, use_custom_avatar").Update(u); err != nil {
 | 
							if _, err := db.GetEngine(ctx).ID(u.ID).Cols("avatar, use_custom_avatar").Update(u); err != nil {
 | 
				
			||||||
			return fmt.Errorf("DeleteAvatar: %w", err)
 | 
								return fmt.Errorf("DeleteAvatar: %w", err)
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	return nil
 | 
					
 | 
				
			||||||
 | 
							if hasAvatar {
 | 
				
			||||||
 | 
								if err := storage.Avatars.Delete(aPath); err != nil {
 | 
				
			||||||
 | 
									if !errors.Is(err, os.ErrNotExist) {
 | 
				
			||||||
 | 
										return fmt.Errorf("failed to remove %s: %w", aPath, err)
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									log.Warn("Deleting avatar %s but it doesn't exist", aPath)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return nil
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user