2021-04-28 16:10:44 -04:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/rand"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/cruxic/go-hmac-drbg/hmacdrbg"
|
2022-11-09 15:53:01 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
2022-01-18 14:17:06 -04:00
|
|
|
"go.uber.org/zap"
|
2021-04-28 16:10:44 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
var brHmacDrbgPool = sync.Pool{New: func() interface{} {
|
|
|
|
seed := make([]byte, 48)
|
|
|
|
_, err := rand.Read(seed)
|
|
|
|
if err != nil {
|
2022-01-18 14:17:06 -04:00
|
|
|
utils.Logger().Fatal("rand.Read err", zap.Error(err))
|
2021-04-28 16:10:44 -04:00
|
|
|
}
|
|
|
|
return hmacdrbg.NewHmacDrbg(256, seed, nil)
|
|
|
|
}}
|
|
|
|
|
2023-09-11 10:24:05 -04:00
|
|
|
// GenerateRequestID generates a random 32 byte slice that can be used for
|
2021-10-09 14:18:53 -04:00
|
|
|
// creating requests inf the filter, store and lightpush protocols
|
2023-09-11 10:24:05 -04:00
|
|
|
func GenerateRequestID() []byte {
|
2021-04-28 16:10:44 -04:00
|
|
|
rng := brHmacDrbgPool.Get().(*hmacdrbg.HmacDrbg)
|
|
|
|
defer brHmacDrbgPool.Put(rng)
|
|
|
|
|
|
|
|
randData := make([]byte, 32)
|
|
|
|
if !rng.Generate(randData) {
|
|
|
|
//Reseed is required every 10,000 calls
|
|
|
|
seed := make([]byte, 48)
|
|
|
|
_, err := rand.Read(seed)
|
|
|
|
if err != nil {
|
2022-01-18 14:17:06 -04:00
|
|
|
utils.Logger().Fatal("rand.Read err", zap.Error(err))
|
2021-04-28 16:10:44 -04:00
|
|
|
}
|
|
|
|
err = rng.Reseed(seed)
|
|
|
|
if err != nil {
|
|
|
|
//only happens if seed < security-level
|
2022-01-18 14:17:06 -04:00
|
|
|
utils.Logger().Fatal("rng.Reseed err", zap.Error(err))
|
2021-04-28 16:10:44 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
if !rng.Generate(randData) {
|
2022-01-18 14:17:06 -04:00
|
|
|
utils.Logger().Error("could not generate random request id")
|
2021-04-28 16:10:44 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return randData
|
|
|
|
}
|