package main import ( "bytes" "encoding/base64" "encoding/binary" "golang.org/x/crypto/ed25519" ) type Sig struct { PKAlg [2]byte KeyNum [KeyNumLen]byte Sig [ed25519.SignatureSize]byte } func (v *Sig) Unmarshal(b []byte) error { buf := bytes.NewBuffer(b) dec := base64.NewDecoder(base64.StdEncoding, buf) err := binary.Read(dec, binary.BigEndian, v) return err } func (v *Sig) Marshal() ([]byte, error) { buf := new(bytes.Buffer) enc := base64.NewEncoder(base64.StdEncoding, buf) err := binary.Write(enc, binary.BigEndian, v) enc.Close() return buf.Bytes(), err }