import (
"encoding/binary"
"golang.org/x/crypto/bcrypt"
+ "io"
"log"
+ "slices"
)
const GuestAccount = "guest" // default account used when no login is provided for a connection
fieldCount := make([]byte, 2)
binary.BigEndian.PutUint16(fieldCount, uint16(len(fields)))
- p = append(p, fieldCount...)
-
+ var fieldBytes []byte
for _, field := range fields {
- p = append(p, field.Payload()...)
+ fieldBytes = append(fieldBytes, field.Payload()...)
}
- return len(p), nil
+ return copy(p, slices.Concat(fieldCount, fieldBytes)), io.EOF
}
// hashAndSalt generates a password hash from a users obfuscated plaintext password