2022-08-19 12:34:07 -04:00
|
|
|
package persistence
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
"errors"
|
2023-03-02 14:25:30 -04:00
|
|
|
|
2023-03-08 11:05:46 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/hash"
|
2022-08-19 12:34:07 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
TimestampLength = 8
|
|
|
|
HashLength = 32
|
|
|
|
DigestLength = HashLength
|
|
|
|
PubsubTopicLength = HashLength
|
|
|
|
DBKeyLength = TimestampLength + PubsubTopicLength + DigestLength
|
|
|
|
)
|
|
|
|
|
|
|
|
type Hash [HashLength]byte
|
|
|
|
|
|
|
|
var (
|
|
|
|
// ErrInvalidByteSize is returned when DBKey can't be created
|
|
|
|
// from a byte slice because it has invalid length.
|
|
|
|
ErrInvalidByteSize = errors.New("byte slice has invalid length")
|
|
|
|
)
|
|
|
|
|
|
|
|
// DBKey key to be stored in a db.
|
|
|
|
type DBKey struct {
|
|
|
|
raw []byte
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bytes returns a bytes representation of the DBKey.
|
|
|
|
func (k *DBKey) Bytes() []byte {
|
|
|
|
return k.raw
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewDBKey creates a new DBKey with the given values.
|
2023-01-07 11:25:55 -04:00
|
|
|
func NewDBKey(senderTimestamp uint64, receiverTimestamp uint64, pubsubTopic string, digest []byte) *DBKey {
|
2023-11-09 20:29:15 -04:00
|
|
|
pubSubHash := make([]byte, PubsubTopicLength)
|
|
|
|
if pubsubTopic != "" {
|
|
|
|
pubSubHash = hash.SHA256([]byte(pubsubTopic))
|
|
|
|
}
|
2022-08-19 12:34:07 -04:00
|
|
|
|
|
|
|
var k DBKey
|
|
|
|
k.raw = make([]byte, DBKeyLength)
|
2023-01-07 11:25:55 -04:00
|
|
|
|
|
|
|
if senderTimestamp == 0 {
|
|
|
|
binary.BigEndian.PutUint64(k.raw, receiverTimestamp)
|
|
|
|
} else {
|
|
|
|
binary.BigEndian.PutUint64(k.raw, senderTimestamp)
|
|
|
|
}
|
|
|
|
|
2022-08-19 12:34:07 -04:00
|
|
|
copy(k.raw[TimestampLength:], pubSubHash[:])
|
|
|
|
copy(k.raw[TimestampLength+PubsubTopicLength:], digest)
|
|
|
|
|
|
|
|
return &k
|
|
|
|
}
|