// Copyright 2015 The Android Open Source Project // // 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. #ifndef BUFFET_ENCRYPTOR_H_ #define BUFFET_ENCRYPTOR_H_ #include <memory> #include <string> #include <base/macros.h> namespace buffet { // An abstract class to perform authenticated encryption. class Encryptor { public: Encryptor() = default; virtual ~Encryptor() = default; // Encrypts and authenticates the given |plaintext| and emits the // |ciphertext|. Returns true on success. virtual bool EncryptWithAuthentication(const std::string& plaintext, std::string* ciphertext) = 0; // Decrypts and authenticates the given |ciphertext| and emits the // |plaintext|. Returns true on success. virtual bool DecryptWithAuthentication(const std::string& ciphertext, std::string* plaintext) = 0; // A factory method to be exported by the default Encryptor implementation // for a given platform. Like a constructor, this method should not perform // any significant initialization work. The caller assumes ownership of the // pointer. static std::unique_ptr<Encryptor> CreateDefaultEncryptor(); private: DISALLOW_COPY_AND_ASSIGN(Encryptor); }; } // namespace buffet #endif // BUFFET_ENCRYPTOR_H_