"fmt"
"golang.org/x/crypto/bcrypt"
"io"
- "log"
"slices"
)
readOffset int // Internal offset to track read progress
}
+func NewAccount(login, name, password string, access accessBitmap) *Account {
+ return &Account{
+ Login: login,
+ Name: name,
+ Password: hashAndSalt([]byte(password)),
+ Access: access,
+ }
+}
+
// Read implements io.Reader interface for Account
func (a *Account) Read(p []byte) (int, error) {
fields := []Field{
// hashAndSalt generates a password hash from a users obfuscated plaintext password
func hashAndSalt(pwd []byte) string {
- hash, err := bcrypt.GenerateFromPassword(pwd, bcrypt.MinCost)
- if err != nil {
- log.Println(err)
- }
+ hash, _ := bcrypt.GenerateFromPassword(pwd, bcrypt.MinCost)
return string(hash)
}