// 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. // /////////////////////////////////////////////////////////////////////////////// #include "walkthrough/write_keyset.h" // [START tink_walkthrough_write_keyset] #include #include #include #include #include "absl/status/status.h" #include "absl/strings/string_view.h" #include "tink/aead.h" #include "tink/json_keyset_writer.h" #include "tink/keyset_handle.h" #include "tink/kms_client.h" #include "tink/kms_clients.h" namespace tink_walkthrough { using ::crypto::tink::JsonKeysetWriter; using ::crypto::tink::util::StatusOr; // Writes a `keyset` to `output_stream` in JSON format; the keyset is encrypted // through a KMS service using the KMS key `master_kms_key_uri`. // // Prerequisites for this example: // - Register AEAD implementations of Tink. // - Register a KMS client that can use `master_kms_key_uri`. // - Create a keyset and obtain a KeysetHandle to it. crypto::tink::util::Status WriteEncryptedKeyset( const crypto::tink::KeysetHandle& keyset, std::unique_ptr output_stream, absl::string_view master_kms_key_uri) { // Create a writer that will write the keyset to output_stream as JSON. StatusOr> writer = JsonKeysetWriter::New(std::move(output_stream)); if (!writer.ok()) return writer.status(); // Get a KMS client for the given key URI. StatusOr kms_client = crypto::tink::KmsClients::Get(master_kms_key_uri); if (!kms_client.ok()) return kms_client.status(); // Get an Aead primitive that uses the KMS service to encrypt/decrypt. StatusOr> kms_aead = (*kms_client)->GetAead(master_kms_key_uri); if (!kms_aead.ok()) return kms_aead.status(); return keyset.Write(writer->get(), **kms_aead); } } // namespace tink_walkthrough // [END tink_walkthrough_write_keyset]