func BoxPublicKeyToKeybaseKID(k saltpack.BoxPublicKey) (ret keybase1.KID) { if k == nil { return ret } p := k.ToKID() return keybase1.KIDFromRawKey(p, KIDNaclDH) }
func (n naclBoxSecretKey) Box( receiver saltpack.BoxPublicKey, nonce *saltpack.Nonce, msg []byte) []byte { ret := box.Seal([]byte{}, msg, (*[24]byte)(nonce), (*[32]byte)(receiver.ToRawBoxKeyPointer()), (*[32]byte)(n.Private)) return ret }
func (n naclBoxSecretKey) Precompute( sender saltpack.BoxPublicKey) saltpack.BoxPrecomputedSharedKey { var res naclBoxPrecomputedSharedKey box.Precompute((*[32]byte)(&res), (*[32]byte)(sender.ToRawBoxKeyPointer()), (*[32]byte)(n.Private)) return res }
func (n naclBoxSecretKey) Unbox( sender saltpack.BoxPublicKey, nonce *saltpack.Nonce, msg []byte) ( []byte, error) { ret, ok := box.Open([]byte{}, msg, (*[24]byte)(nonce), (*[32]byte)(sender.ToRawBoxKeyPointer()), (*[32]byte)(n.Private)) if !ok { return nil, DecryptionError{} } return ret, nil }