mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	Safe compare password (timing attack) (#338)
This commit is contained in:
		
				
					committed by
					
						 Lunny Xiao
						Lunny Xiao
					
				
			
			
				
	
			
			
			
						parent
						
							db6a4e9fbf
						
					
				
				
					commit
					c8f300b2cd
				
			| @@ -8,6 +8,7 @@ import ( | |||||||
| 	"bytes" | 	"bytes" | ||||||
| 	"container/list" | 	"container/list" | ||||||
| 	"crypto/sha256" | 	"crypto/sha256" | ||||||
|  | 	"crypto/subtle" | ||||||
| 	"encoding/hex" | 	"encoding/hex" | ||||||
| 	"errors" | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| @@ -368,7 +369,7 @@ func (u *User) EncodePasswd() { | |||||||
| func (u *User) ValidatePassword(passwd string) bool { | func (u *User) ValidatePassword(passwd string) bool { | ||||||
| 	newUser := &User{Passwd: passwd, Salt: u.Salt} | 	newUser := &User{Passwd: passwd, Salt: u.Salt} | ||||||
| 	newUser.EncodePasswd() | 	newUser.EncodePasswd() | ||||||
| 	return u.Passwd == newUser.Passwd | 	return subtle.ConstantTimeCompare([]byte(u.Passwd), []byte(newUser.Passwd)) == 1 | ||||||
| } | } | ||||||
|  |  | ||||||
| // UploadAvatar saves custom avatar for user. | // UploadAvatar saves custom avatar for user. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user