blob: ddaf807fc4259df39e370ca3bb2ba8b021743d00 [file] [log] [blame]
// 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 <fstream>
#include <memory>
#include <ostream>
#include <utility>
#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<std::ostream> output_stream,
absl::string_view master_kms_key_uri) {
// Create a writer that will write the keyset to output_stream as JSON.
StatusOr<std::unique_ptr<JsonKeysetWriter>> writer =
JsonKeysetWriter::New(std::move(output_stream));
if (!writer.ok()) return writer.status();
// Get a KMS client for the given key URI.
StatusOr<const crypto::tink::KmsClient*> 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<std::unique_ptr<crypto::tink::Aead>> 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]