// Copyright 2022 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // //////////////////////////////////////////////////////////////////////////////// package hpke import ( "errors" "fmt" "github.com/google/tink/go/tink" pb "github.com/google/tink/go/proto/hpke_go_proto" ) // Encrypt for HPKE implements interface HybridEncrypt. type Encrypt struct { recipientPubKey *pb.HpkePublicKey kem kem kdf kdf aead aead } var _ tink.HybridEncrypt = (*Encrypt)(nil) // NewEncrypt constructs an Encrypt using HpkePublicKey. func NewEncrypt(recipientPubKey *pb.HpkePublicKey) (*Encrypt, error) { if recipientPubKey.GetPublicKey() == nil || len(recipientPubKey.GetPublicKey()) == 0 { return nil, errors.New("HpkePublicKey.PublicKey bytes are missing") } kem, kdf, aead, err := newPrimitivesFromProto(recipientPubKey.GetParams()) if err != nil { return nil, err } return &Encrypt{recipientPubKey, kem, kdf, aead}, nil } // Encrypt encrypts plaintext, binding contextInfo to the resulting ciphertext. func (e *Encrypt) Encrypt(plaintext, contextInfo []byte) ([]byte, error) { ctx, err := newSenderContext(e.recipientPubKey, e.kem, e.kdf, e.aead, contextInfo) if err != nil { return nil, fmt.Errorf("newSenderContext: %v", err) } ciphertext, err := ctx.seal(plaintext, emptyAssociatedData) if err != nil { return nil, fmt.Errorf("seal: %v", err) } return append(ctx.encapsulatedKey, ciphertext...), nil }