mirror of https://github.com/go-gitea/gitea
Git with a cup of tea, painless self-hosted git service
Mirror for internal git.with.parts use
https://git.with.parts
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
34 lines
842 B
34 lines
842 B
2 years ago
|
// 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{}
|
||
|
}
|