2021-07-13 21:35:15 +00:00
|
|
|
package splitstore
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
|
|
|
|
cid "github.com/ipfs/go-cid"
|
|
|
|
mh "github.com/multiformats/go-multihash"
|
2022-06-14 15:00:51 +00:00
|
|
|
"golang.org/x/xerrors"
|
2021-07-13 21:35:15 +00:00
|
|
|
|
|
|
|
"github.com/filecoin-project/go-state-types/abi"
|
|
|
|
)
|
|
|
|
|
|
|
|
func epochToBytes(epoch abi.ChainEpoch) []byte {
|
|
|
|
return uint64ToBytes(uint64(epoch))
|
|
|
|
}
|
|
|
|
|
|
|
|
func bytesToEpoch(buf []byte) abi.ChainEpoch {
|
|
|
|
return abi.ChainEpoch(bytesToUint64(buf))
|
|
|
|
}
|
|
|
|
|
|
|
|
func int64ToBytes(i int64) []byte {
|
|
|
|
return uint64ToBytes(uint64(i))
|
|
|
|
}
|
|
|
|
|
|
|
|
func bytesToInt64(buf []byte) int64 {
|
|
|
|
return int64(bytesToUint64(buf))
|
|
|
|
}
|
|
|
|
|
|
|
|
func uint64ToBytes(i uint64) []byte {
|
|
|
|
buf := make([]byte, 16)
|
|
|
|
n := binary.PutUvarint(buf, i)
|
|
|
|
return buf[:n]
|
|
|
|
}
|
|
|
|
|
|
|
|
func bytesToUint64(buf []byte) uint64 {
|
|
|
|
i, _ := binary.Uvarint(buf)
|
|
|
|
return i
|
|
|
|
}
|
|
|
|
|
|
|
|
func isUnitaryObject(c cid.Cid) bool {
|
|
|
|
pre := c.Prefix()
|
|
|
|
switch pre.Codec {
|
|
|
|
case cid.FilCommitmentSealed, cid.FilCommitmentUnsealed:
|
|
|
|
return true
|
|
|
|
default:
|
|
|
|
return pre.MhType == mh.IDENTITY
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func isIdentiyCid(c cid.Cid) bool {
|
|
|
|
return c.Prefix().MhType == mh.IDENTITY
|
|
|
|
}
|
|
|
|
|
|
|
|
func decodeIdentityCid(c cid.Cid) ([]byte, error) {
|
|
|
|
dmh, err := mh.Decode(c.Hash())
|
|
|
|
if err != nil {
|
|
|
|
return nil, xerrors.Errorf("error decoding identity cid %s: %w", c, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// sanity check
|
|
|
|
if dmh.Code != mh.IDENTITY {
|
|
|
|
return nil, xerrors.Errorf("error decoding identity cid %s: hash type is not identity", c)
|
|
|
|
}
|
|
|
|
|
|
|
|
return dmh.Digest, nil
|
|
|
|
}
|