mox/mox-/rand.go

24 lines
532 B
Go
Raw Normal View History

2023-01-30 16:27:06 +03:00
package mox
import (
cryptorand "crypto/rand"
"encoding/binary"
"fmt"
mathrand "math/rand"
)
// NewRand returns a new PRNG seeded with random bytes from crypto/rand.
func NewRand() *mathrand.Rand {
return mathrand.New(mathrand.NewSource(CryptoRandInt()))
2023-01-30 16:27:06 +03:00
}
// CryptoRandInt returns a cryptographically random number.
func CryptoRandInt() int64 {
2023-01-30 16:27:06 +03:00
buf := make([]byte, 8)
_, err := cryptorand.Read(buf)
if err != nil {
panic(fmt.Errorf("reading random bytes: %v", err))
}
return int64(binary.LittleEndian.Uint64(buf))
}