mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-30 04:15:21 +00:00
ef11d41639
During the recent hash algorithm change it became clear that the choice of password hash algorithm plays a role in the time taken for CI to run. Therefore as attempt to improve CI we should consider using a dummy hashing algorithm instead of a real hashing algorithm. This PR creates a dummy algorithm which is then set as the default hashing algorithm during tests that use the fixtures. This hopefully will cause a reduction in the time it takes for CI to run. --------- Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
34 lines
842 B
Go
34 lines
842 B
Go
// Copyright 2023 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package hash
|
|
|
|
import (
|
|
"encoding/hex"
|
|
)
|
|
|
|
// DummyHasher implements PasswordHasher and is a dummy hasher that simply
|
|
// puts the password in place with its salt
|
|
// This SHOULD NOT be used in production and is provided to make the integration
|
|
// tests faster only
|
|
type DummyHasher struct{}
|
|
|
|
// HashWithSaltBytes a provided password and salt
|
|
func (hasher *DummyHasher) HashWithSaltBytes(password string, salt []byte) string {
|
|
if hasher == nil {
|
|
return ""
|
|
}
|
|
|
|
if len(salt) == 10 {
|
|
return string(salt) + ":" + password
|
|
}
|
|
|
|
return hex.EncodeToString(salt) + ":" + password
|
|
}
|
|
|
|
// NewDummyHasher is a factory method to create a DummyHasher
|
|
// Any provided configuration is ignored
|
|
func NewDummyHasher(_ string) *DummyHasher {
|
|
return &DummyHasher{}
|
|
}
|