Merge pull request #5 from euphoria-laxis/release/v2.1.0
Some checks failed
Test github.com/euphoria-laxis/argon2 / build (push) Has been cancelled

Remove useless options for decoder
This commit is contained in:
Euphoria Laxis 2024-03-01 16:28:20 +01:00 committed by GitHub
commit 8c8fb8c6b9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 12 additions and 18 deletions

View File

@ -36,7 +36,7 @@ func TestEncoder(t *testing.T) {
}
func TestDecoder(t *testing.T) {
decoder, _ := NewDecoder(opts...)
decoder := NewDecoder()
match, err := decoder.CompareStringToHash(randomString, hashedString)
if err != nil {
log.Print(err)

View File

@ -8,20 +8,13 @@ import (
"strings"
)
type Decoder struct {
Options
type Decoder struct{}
func NewDecoder() *Decoder {
return new(Decoder)
}
func NewDecoder(opts ...OptFunc) (*Decoder, *Options) {
o := defaultOptions
for _, fn := range opts {
fn(&o)
}
return &Decoder{o}, &o
}
func (decoder *Decoder) decodeHash(encodedHash string) (d *Decoder, salt, hash []byte, err error) {
func (decoder *Decoder) decodeHash(encodedHash string) (o *Options, salt, hash []byte, err error) {
values := strings.Split(encodedHash, "$")
if len(values) != 6 {
return nil, nil, nil, ErrInvalidHash
@ -34,7 +27,8 @@ func (decoder *Decoder) decodeHash(encodedHash string) (d *Decoder, salt, hash [
if version != argon2.Version {
return nil, nil, nil, ErrIncompatibleVersion
}
_, err = fmt.Sscanf(values[3], "m=%d,t=%d,p=%d", &decoder.Memory, &decoder.Iterations, &decoder.Parallelism)
o = new(Options)
_, err = fmt.Sscanf(values[3], "m=%d,t=%d,p=%d", &o.Memory, &o.Iterations, &o.Parallelism)
if err != nil {
return nil, nil, nil, err
}
@ -42,15 +36,15 @@ func (decoder *Decoder) decodeHash(encodedHash string) (d *Decoder, salt, hash [
if err != nil {
return nil, nil, nil, err
}
d = decoder
d.SaltLength = uint32(len(salt))
o.SaltLength = uint32(len(salt))
hash, err = base64.RawStdEncoding.DecodeString(values[5])
if err != nil {
return nil, nil, nil, err
}
d.KeyLength = uint32(len(hash))
o.KeyLength = uint32(len(hash))
return d, salt, hash, nil
return o, salt, hash, nil
}
func (decoder *Decoder) CompareStringToHash(password string, hashedPassword string) (match bool, err error) {