kmscng/util/status_utils.h (13 lines of code) (raw):
/*
* Copyright 2023 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.
*/
#ifndef KMSCNG_UTIL_STATUS_UTILS_H_
#define KMSCNG_UTIL_STATUS_UTILS_H_
// clang-format off
#include <windows.h>
#include <wincrypt.h>
// clang-format on
#include "absl/status/status.h"
#include "absl/status/statusor.h"
#include "grpcpp/support/status.h"
namespace cloud_kms::kmscng {
// A catch-all default SECURITY_STATUS value to return in the event that no
// specific error is provided.
const SECURITY_STATUS kDefaultErrorStatus = NTE_FAIL;
// Set a SECURITY_STATUS that should be provided to the caller. This may not be
// set for an `ok` status, and ERROR_SUCCESS may not be set as the return
// value. These requirements are CHECKed.
void SetErrorSs(absl::Status& status, SECURITY_STATUS ss);
// Get a SECURITY_STATUS suitable for returning to a caller. For an `ok` status,
// this is always ERROR_SUCCESS. For a non-OK status, this is the value that was
// set using SetErrorSt, or if no value was set, `kDefaultErrorCkRv`.
SECURITY_STATUS GetErrorSs(const absl::Status& status);
} // namespace cloud_kms::kmscng
#endif // KMSCNG_UTIL_STATUS_UTILS_H_