diff options
author | Gusted <postmaster@gusted.xyz> | 2023-01-02 22:46:39 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-01-02 22:46:39 +0100 |
commit | 96797fed311151ff889f87c94c7b6aaa16c5d535 (patch) | |
tree | 30892e553fa197e8205b9d1ddad82aef3e707caa /modules | |
parent | fcd6ceef2b76aabd6a8ffab688492cc7f69269bf (diff) | |
download | gitea-96797fed311151ff889f87c94c7b6aaa16c5d535.tar.gz gitea-96797fed311151ff889f87c94c7b6aaa16c5d535.zip |
Unify hashing for avatar (#22289)
- Unify the hashing code for repository and user avatars into a
function.
- Use a sane hash function instead of MD5.
- Only require hashing once instead of twice(w.r.t. hashing for user
avatar).
- Improve the comment for the hashing code of why it works.
Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
Co-authored-by: Yarden Shoham <hrsi88@gmail.com>
Diffstat (limited to 'modules')
-rw-r--r-- | modules/avatar/hash.go | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/modules/avatar/hash.go b/modules/avatar/hash.go new file mode 100644 index 0000000000..50db9c1943 --- /dev/null +++ b/modules/avatar/hash.go @@ -0,0 +1,28 @@ +// Copyright 2023 The Gitea Authors. All rights reserved. +// SPDX-License-Identifier: MIT + +package avatar + +import ( + "crypto/sha256" + "encoding/hex" + "strconv" +) + +// HashAvatar will generate a unique string, which ensures that when there's a +// different unique ID while the data is the same, it will generate a different +// output. It will generate the output according to: +// HEX(HASH(uniqueID || - || data)) +// The hash being used is SHA256. +// The sole purpose of the unique ID is to generate a distinct hash Such that +// two unique IDs with the same data will have a different hash output. +// The "-" byte is important to ensure that data cannot be modified such that +// the first byte is a number, which could lead to a "collision" with the hash +// of another unique ID. +func HashAvatar(uniqueID int64, data []byte) string { + h := sha256.New() + h.Write([]byte(strconv.FormatInt(uniqueID, 10))) + h.Write([]byte{'-'}) + h.Write(data) + return hex.EncodeToString(h.Sum(nil)) +} |