#ifndef GRPC_SRC_CORE_LIB_SECURITY_CREDENTIALS_CREDENTIALS_H
#define GRPC_SRC_CORE_LIB_SECURITY_CREDENTIALS_CREDENTIALS_H
#include <grpc/support/port_platform.h>
#include <string>
#include <utility>
#include <vector>
#include "absl/status/statusor.h"
#include "absl/strings/string_view.h"
#include <grpc/grpc.h>
#include <grpc/grpc_security.h>
#include <grpc/grpc_security_constants.h>
#include <grpc/impl/grpc_types.h>
#include <grpc/support/log.h>
#include "src/core/lib/channel/channel_args.h"
#include "src/core/lib/gprpp/crash.h"
#include "src/core/lib/gprpp/ref_counted.h"
#include "src/core/lib/gprpp/ref_counted_ptr.h"
#include "src/core/lib/gprpp/unique_type_name.h"
#include "src/core/lib/promise/arena_promise.h"
#include "src/core/lib/security/security_connector/security_connector.h"
#include "src/core/lib/slice/slice.h"
#include "src/core/lib/transport/transport.h"
typedef enum {
GRPC_CREDENTIALS_OK = 0,
GRPC_CREDENTIALS_ERROR
} grpc_credentials_status;
#define GRPC_FAKE_TRANSPORT_SECURITY_TYPE "fake"
#define GRPC_AUTHORIZATION_METADATA_KEY "authorization"
#define GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY \
"x-goog-iam-authorization-token"
#define GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY "x-goog-iam-authority-selector"
#define GRPC_SECURE_TOKEN_REFRESH_THRESHOLD_SECS 60
#define GRPC_COMPUTE_ENGINE_METADATA_HOST "metadata.google.internal."
#define GRPC_COMPUTE_ENGINE_METADATA_TOKEN_PATH \
"/computeMetadata/v1/instance/service-accounts/default/token"
#define GRPC_GOOGLE_OAUTH2_SERVICE_HOST "oauth2.googleapis.com"
#define GRPC_GOOGLE_OAUTH2_SERVICE_TOKEN_PATH "/token"
#define GRPC_SERVICE_ACCOUNT_POST_BODY_PREFIX \
"grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Ajwt-bearer&" \
"assertion="
#define GRPC_REFRESH_TOKEN_POST_BODY_FORMAT_STRING \
"client_id=%s&client_secret=%s&refresh_token=%s&grant_type=refresh_token"
std::string grpc_get_well_known_google_credentials_file_path(void);
std::string grpc_get_well_known_google_credentials_file_path_impl(void);
typedef std::string (*grpc_well_known_credentials_path_getter)(void);
void grpc_override_well_known_credentials_path_getter(
grpc_well_known_credentials_path_getter getter);
#define GRPC_ARG_CHANNEL_CREDENTIALS "grpc.internal.channel_credentials"
struct grpc_channel_credentials
: grpc_core::RefCounted<grpc_channel_credentials> {
public:
static absl::string_view ChannelArgName() {
return GRPC_ARG_CHANNEL_CREDENTIALS;
}
static int ChannelArgsCompare(const grpc_channel_credentials* args1,
const grpc_channel_credentials* args2) {
return args1->cmp(args2);
}
virtual grpc_core::RefCountedPtr<grpc_channel_security_connector>
create_security_connector(
grpc_core::RefCountedPtr<grpc_call_credentials> call_creds,
const char* target, grpc_core::ChannelArgs* args) = 0;
virtual grpc_core::RefCountedPtr<grpc_channel_credentials>
duplicate_without_call_credentials() {
return Ref();
}
virtual grpc_core::ChannelArgs update_arguments(grpc_core::ChannelArgs args) {
return args;
}
int cmp(const grpc_channel_credentials* other) const {
GPR_ASSERT(other != nullptr);
int r = type().Compare(other->type());
if (r != 0) return r;
return cmp_impl(other);
}
virtual grpc_core::UniqueTypeName type() const = 0;
private:
virtual int cmp_impl(const grpc_channel_credentials* other) const = 0;
};
grpc_arg grpc_channel_credentials_to_arg(grpc_channel_credentials* credentials);
grpc_channel_credentials* grpc_channel_credentials_from_arg(
const grpc_arg* arg);
grpc_channel_credentials* grpc_channel_credentials_find_in_args(
const grpc_channel_args* args);
namespace grpc_core {
using CredentialsMetadataArray = std::vector<std::pair<Slice, Slice>>;
}
struct grpc_call_credentials
: public grpc_core::RefCounted<grpc_call_credentials> {
public:
struct GetRequestMetadataArgs {
grpc_core::RefCountedPtr<grpc_channel_security_connector>
security_connector;
grpc_core::RefCountedPtr<grpc_auth_context> auth_context;
};
explicit grpc_call_credentials(
grpc_security_level min_security_level = GRPC_PRIVACY_AND_INTEGRITY)
: min_security_level_(min_security_level) {}
~grpc_call_credentials() override = default;
virtual grpc_core::ArenaPromise<
absl::StatusOr<grpc_core::ClientMetadataHandle>>
GetRequestMetadata(grpc_core::ClientMetadataHandle initial_metadata,
const GetRequestMetadataArgs* args) = 0;
virtual grpc_security_level min_security_level() const {
return min_security_level_;
}
int cmp(const grpc_call_credentials* other) const {
GPR_ASSERT(other != nullptr);
int r = type().Compare(other->type());
if (r != 0) return r;
return cmp_impl(other);
}
virtual std::string debug_string() {
return "grpc_call_credentials did not provide debug string";
}
virtual grpc_core::UniqueTypeName type() const = 0;
private:
virtual int cmp_impl(const grpc_call_credentials* other) const = 0;
const grpc_security_level min_security_level_;
};
grpc_call_credentials* grpc_md_only_test_credentials_create(
const char* md_key, const char* md_value);
#define GRPC_SERVER_CREDENTIALS_ARG "grpc.internal.server_credentials"
struct grpc_server_credentials
: public grpc_core::RefCounted<grpc_server_credentials> {
public:
~grpc_server_credentials() override { DestroyProcessor(); }
static absl::string_view ChannelArgName() {
return GRPC_SERVER_CREDENTIALS_ARG;
}
static int ChannelArgsCompare(const grpc_server_credentials* a,
const grpc_server_credentials* b) {
return grpc_core::QsortCompare(a, b);
}
virtual grpc_core::RefCountedPtr<grpc_server_security_connector>
create_security_connector(const grpc_core::ChannelArgs& args) = 0;
virtual grpc_core::UniqueTypeName type() const = 0;
const grpc_auth_metadata_processor& auth_metadata_processor() const {
return processor_;
}
void set_auth_metadata_processor(
const grpc_auth_metadata_processor& processor);
private:
void DestroyProcessor() {
if (processor_.destroy != nullptr && processor_.state != nullptr) {
processor_.destroy(processor_.state);
}
}
grpc_auth_metadata_processor processor_ =
grpc_auth_metadata_processor(); };
grpc_arg grpc_server_credentials_to_arg(grpc_server_credentials* c);
grpc_server_credentials* grpc_server_credentials_from_arg(const grpc_arg* arg);
grpc_server_credentials* grpc_find_server_credentials_in_args(
const grpc_channel_args* args);
#endif