Documentation ¶
Index ¶
- Constants
- Variables
- func CalculateSegments(fileSize uint64) (numSegments uint64)
- func GenerateSignatureKeys() (sk SecretKey, pk PublicKey, err error)
- func NewHash() hash.Hash
- func NewTree() tree
- func VerifyHash(data Hash, pk PublicKey, sig Signature) (err error)
- func VerifySegment(base [SegmentSize]byte, hashSet []Hash, numSegments, proofIndex uint64, ...) bool
- type Hash
- func BuildReaderProof(r io.Reader, proofIndex uint64) (base [SegmentSize]byte, hashSet []Hash, err error)
- func HashAll(objs ...interface{}) Hash
- func HashBytes(data []byte) Hash
- func HashObject(obj interface{}) Hash
- func MerkleRoot(leaves [][]byte) (h Hash)
- func ReaderMerkleRoot(r io.Reader) (h Hash, err error)
- type HashSlice
- type PublicKey
- type SecretKey
- type Signature
- type TwofishKey
Constants ¶
const ( PublicKeySize = ed25519.PublicKeySize SecretKeySize = ed25519.PrivateKeySize SignatureSize = ed25519.SignatureSize )
const (
HashSize = 32
)
const (
SegmentSize = 64 // number of bytes that are hashed to form each base leaf of the Merkle tree
)
Variables ¶
var ( ErrNilInput = errors.New("cannot use nil input") ErrInvalidSignature = errors.New("invalid signature") )
Functions ¶
func CalculateSegments ¶
Calculates the number of segments in the file when building a Merkle tree. Should probably be renamed to CountLeaves() or something.
func GenerateSignatureKeys ¶
GenerateKeyPair creates a public-secret keypair that can be used to sign and verify messages.
func VerifyHash ¶
VerifyHash uses a public key and input data to verify a signature. And error is returned if the public key or signature is nil.
func VerifySegment ¶
Types ¶
type Hash ¶
func BuildReaderProof ¶
func HashAll ¶
func HashAll(objs ...interface{}) Hash
HashAll takes a set of objects as input, encodes them all using the encoding package, and then hashes the result.
func HashObject ¶
func HashObject(obj interface{}) Hash
HashObject takes an object as input, encodes it using the encoding package, and then hashes the result.
func MerkleRoot ¶
MerkleRoot calculates the "root hash" formed by repeatedly concatenating and hashing a binary tree of hashes. If the number of leaves is not a power of 2, the orphan hash(es) are not rehashed. Examples:
┌───┴──┐ ┌────┴───┐ ┌─────┴─────┐ ┌──┴──┐ │ ┌──┴──┐ │ ┌──┴──┐ ┌──┴──┐ ┌─┴─┐ ┌─┴─┐ │ ┌─┴─┐ ┌─┴─┐ ┌─┴─┐ ┌─┴─┐ ┌─┴─┐ ┌─┴─┐ │ (5-leaf) (6-leaf) (7-leaf)
type HashSlice ¶
type HashSlice []Hash
HashSlice is used for sorting
type PublicKey ¶
type PublicKey [ed25519.PublicKeySize]byte
type SecretKey ¶
type SecretKey [ed25519.PrivateKeySize]byte
type Signature ¶
type Signature [ed25519.SignatureSize]byte
type TwofishKey ¶
type TwofishKey [32]byte
func GenerateTwofishKey ¶
func GenerateTwofishKey() (key TwofishKey, err error)
GenerateEncryptionKey produces a key that can be used for encrypting and decrypting files.
func (TwofishKey) DecryptBytes ¶
func (key TwofishKey) DecryptBytes(ciphertext []byte, iv []byte, padding int) (plaintext []byte, err error)
DecryptBytes decrypts a ciphertext using the key, an iv, and a volume of padding. `ciphertext` is not overwritten. The plaintext is returned.
func (TwofishKey) EncryptBytes ¶
func (key TwofishKey) EncryptBytes(plaintext []byte) (ciphertext []byte, iv []byte, padding int, err error)
EncryptBytes encrypts a []byte using the key. The padded ciphertext, iv, and amount of padding used are returned. `plaintext` is not overwritten.