h2_tls.cc
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2018 gRPC authors.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  */
18 
19 #include <stdio.h>
20 #include <string.h>
21 
22 #include "absl/container/inlined_vector.h"
23 
24 #include <grpc/grpc_security.h>
25 #include <grpc/support/alloc.h>
26 #include <grpc/support/log.h>
28 
30 #include "src/core/lib/gpr/env.h"
34 #include "src/core/lib/gprpp/thd.h"
40 #include "test/core/util/port.h"
43 
44 // For normal TLS connections.
45 #define CA_CERT_PATH "src/core/tsi/test_creds/ca.pem"
46 #define SERVER_CERT_PATH "src/core/tsi/test_creds/server1.pem"
47 #define SERVER_KEY_PATH "src/core/tsi/test_creds/server1.key"
48 
50 
53  enum VerifierType {
57  } verifier_type;
58  enum TlsVersion { V_12 = 0, V_13 = 1 } tls_version;
59 };
60 
67  }
74  bool check_call_host = true;
75 };
76 
78  SecurityPrimitives::TlsVersion tls_version) {
79  switch (tls_version) {
80  case SecurityPrimitives::TlsVersion::V_12: {
82  break;
83  }
84  case SecurityPrimitives::TlsVersion::V_13: {
86  break;
87  }
88  }
89 }
90 
93  SecurityPrimitives::ProviderType provider_type) {
94  switch (provider_type) {
95  case SecurityPrimitives::ProviderType::STATIC_PROVIDER: {
96  grpc_slice root_slice, cert_slice, key_slice;
98  "load_file", grpc_load_file(CA_CERT_PATH, 1, &root_slice)));
99  std::string root_cert =
102  "load_file", grpc_load_file(SERVER_CERT_PATH, 1, &cert_slice)));
103  std::string identity_cert =
106  "load_file", grpc_load_file(SERVER_KEY_PATH, 1, &key_slice)));
110  grpc_tls_identity_pairs_add_pair(client_pairs, private_key.c_str(),
111  identity_cert.c_str());
113  root_cert.c_str(), client_pairs);
115  grpc_tls_identity_pairs_add_pair(server_pairs, private_key.c_str(),
116  identity_cert.c_str());
118  root_cert.c_str(), server_pairs);
119  grpc_slice_unref(root_slice);
120  grpc_slice_unref(cert_slice);
121  grpc_slice_unref(key_slice);
122  break;
123  }
124  case SecurityPrimitives::ProviderType::FILE_PROVIDER: {
129  break;
130  }
131  }
132 }
133 
136  SecurityPrimitives::VerifierType verifier_type) {
137  switch (verifier_type) {
138  case SecurityPrimitives::VerifierType::EXTERNAL_SYNC_VERIFIER: {
139  auto* client_sync_verifier =
142  client_sync_verifier->base());
143  auto* server_sync_verifier =
146  server_sync_verifier->base());
147  ffd->check_call_host = false;
148  break;
149  }
150  case SecurityPrimitives::VerifierType::EXTERNAL_ASYNC_VERIFIER: {
151  auto* client_async_verifier =
154  client_async_verifier->base());
155  auto* server_async_verifier =
158  server_async_verifier->base());
159  ffd->check_call_host = false;
160  break;
161  }
162  case SecurityPrimitives::VerifierType::HOSTNAME_VERIFIER: {
164  // Hostname verifier couldn't be applied to the server side, so we will
165  // use sync external verifier here.
166  auto* server_async_verifier =
169  server_async_verifier->base());
170  break;
171  }
172  }
173 }
174 
176  const grpc_channel_args*, const grpc_channel_args*) {
180  memset(&f, 0, sizeof(f));
181  ffd->localaddr = grpc_core::JoinHostPort("localhost", port);
182  SetTlsVersion(ffd, SecurityPrimitives::TlsVersion::V_12);
184  SecurityPrimitives::ProviderType::STATIC_PROVIDER);
186  ffd, SecurityPrimitives::VerifierType::EXTERNAL_SYNC_VERIFIER);
187  f.fixture_data = ffd;
189  return f;
190 }
191 
193  const grpc_channel_args*, const grpc_channel_args*) {
197  memset(&f, 0, sizeof(f));
198  ffd->localaddr = grpc_core::JoinHostPort("localhost", port);
199  SetTlsVersion(ffd, SecurityPrimitives::TlsVersion::V_13);
201  SecurityPrimitives::ProviderType::STATIC_PROVIDER);
203  ffd, SecurityPrimitives::VerifierType::EXTERNAL_ASYNC_VERIFIER);
204  f.fixture_data = ffd;
206  return f;
207 }
208 
211  const grpc_channel_args*) {
215  memset(&f, 0, sizeof(f));
216  ffd->localaddr = grpc_core::JoinHostPort("localhost", port);
217  SetTlsVersion(ffd, SecurityPrimitives::TlsVersion::V_12);
218  SetCertificateProvider(ffd, SecurityPrimitives::ProviderType::FILE_PROVIDER);
220  SecurityPrimitives::VerifierType::HOSTNAME_VERIFIER);
221  f.fixture_data = ffd;
223  return f;
224 }
225 
228  const grpc_channel_args*) {
232  memset(&f, 0, sizeof(f));
233  ffd->localaddr = grpc_core::JoinHostPort("localhost", port);
234  SetTlsVersion(ffd, SecurityPrimitives::TlsVersion::V_12);
235  SetCertificateProvider(ffd, SecurityPrimitives::ProviderType::FILE_PROVIDER);
237  ffd, SecurityPrimitives::VerifierType::EXTERNAL_ASYNC_VERIFIER);
238  f.fixture_data = ffd;
240  return f;
241 }
242 
243 static void process_auth_failure(void* state, grpc_auth_context* /*ctx*/,
244  const grpc_metadata* /*md*/,
245  size_t /*md_count*/,
247  void* user_data) {
248  GPR_ASSERT(state == nullptr);
249  cb(user_data, nullptr, 0, nullptr, 0, GRPC_STATUS_UNAUTHENTICATED, nullptr);
250 }
251 
253  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args,
254  grpc_channel_credentials* creds) {
256  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
257  f->client = grpc_channel_create(ffd->localaddr.c_str(), creds, client_args);
258  GPR_ASSERT(f->client != nullptr);
260 }
261 
263  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args,
264  grpc_server_credentials* server_creds) {
266  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
267  if (f->server) {
268  grpc_server_destroy(f->server);
269  }
270  f->server = grpc_server_create(server_args, nullptr);
271  grpc_server_register_completion_queue(f->server, f->cq, nullptr);
272  GPR_ASSERT(grpc_server_add_http2_port(f->server, ffd->localaddr.c_str(),
273  server_creds));
274  grpc_server_credentials_release(server_creds);
275  grpc_server_start(f->server);
276 }
277 
280  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
281  delete ffd;
282 }
283 
284 // Create a TLS channel credential.
289  options, 1 /* = verify server certs */);
290  options->set_min_tls_version(ffd->tls_version);
291  options->set_max_tls_version(ffd->tls_version);
292  // Set credential provider.
294  ffd->client_provider);
297  // Set credential verifier.
299  ffd->client_verifier);
301  ffd->check_call_host);
302  /* Create TLS channel credentials. */
304  return creds;
305 }
306 
307 // Create a TLS server credential.
311  options->set_min_tls_version(ffd->tls_version);
312  options->set_max_tls_version(ffd->tls_version);
313  // Set credential provider.
315  ffd->server_provider);
318  // Set client certificate request type.
321  // Set credential verifier.
323  ffd->server_verifier);
325  return creds;
326 }
327 
329  const grpc_channel_args* client_args) {
331  static_cast<fullstack_secure_fixture_data*>(f->fixture_data));
332  grpc_arg ssl_name_override = {
334  const_cast<char*>(GRPC_SSL_TARGET_NAME_OVERRIDE_ARG),
335  {const_cast<char*>("foo.test.google.fr")}};
336  const grpc_channel_args* new_client_args =
337  grpc_channel_args_copy_and_add(client_args, &ssl_name_override, 1);
338  chttp2_init_client_secure_fullstack(f, new_client_args, ssl_creds);
339  grpc_channel_args_destroy(new_client_args);
340 }
341 
342 static int fail_server_auth_check(const grpc_channel_args* server_args) {
343  size_t i;
344  if (server_args == nullptr) return 0;
345  for (i = 0; i < server_args->num_args; i++) {
346  if (strcmp(server_args->args[i].key, FAIL_AUTH_CHECK_SERVER_ARG_NAME) ==
347  0) {
348  return 1;
349  }
350  }
351  return 0;
352 }
353 
355  const grpc_channel_args* server_args) {
357  static_cast<fullstack_secure_fixture_data*>(f->fixture_data));
358  if (fail_server_auth_check(server_args)) {
360  nullptr};
362  }
363  chttp2_init_server_secure_fullstack(f, server_args, ssl_creds);
364 }
365 
371 
373  // client: static data provider + sync external verifier
374  // server: static data provider + sync external verifier
375  // extra: TLS 1.2
376  {"chttp2/simple_ssl_fullstack", kH2TLSFeatureMask, "foo.test.google.fr",
379  // client: static data provider + async external verifier
380  // server: static data provider + async external verifier
381  // extra: TLS 1.3
382  {"chttp2/static_provider_async_verifier_tls1_3", kH2TLSFeatureMask,
383  "foo.test.google.fr", chttp2_create_fixture_async_verifier,
385  // client: certificate watcher provider + hostname verifier
386  // server: certificate watcher provider + sync external verifier
387  // extra: TLS 1.2
388  {"chttp2/cert_watcher_provider_sync_verifier_tls1_2", kH2TLSFeatureMask,
391  // client: certificate watcher provider + async external verifier
392  // server: certificate watcher provider + async external verifier
393  // extra: TLS 1.3
394  {"chttp2/cert_watcher_provider_async_verifier_tls1_3", kH2TLSFeatureMask,
397 };
398 
399 int main(int argc, char** argv) {
400  grpc::testing::TestEnvironment env(&argc, argv);
402  GPR_GLOBAL_CONFIG_SET(grpc_default_ssl_roots_file_path, CA_CERT_PATH);
403  grpc_init();
404  for (size_t ind = 0; ind < sizeof(configs) / sizeof(*configs); ind++) {
405  grpc_end2end_tests(argc, argv, configs[ind]);
406  }
407  grpc_shutdown();
408  return 0;
409 }
main
int main(int argc, char **argv)
Definition: h2_tls.cc:399
grpc_arg
Definition: grpc_types.h:103
grpc_slice_unref
GPRAPI void grpc_slice_unref(grpc_slice s)
Definition: slice_api.cc:32
grpc_tls_credentials_options_set_certificate_provider
GRPCAPI void grpc_tls_credentials_options_set_certificate_provider(grpc_tls_credentials_options *options, grpc_tls_certificate_provider *provider)
Definition: grpc_tls_credentials_options.cc:51
fullstack_secure_fixture_data::client_provider
grpc_tls_certificate_provider * client_provider
Definition: h2_tls.cc:70
FEATURE_MASK_SUPPORTS_AUTHORITY_HEADER
#define FEATURE_MASK_SUPPORTS_AUTHORITY_HEADER
Definition: end2end_tests.h:38
grpc_auth_context
Definition: security_context.h:63
log.h
port.h
fullstack_secure_fixture_data::localaddr
std::string localaddr
Definition: h2_fakesec.cc:33
grpc_core::testing::SyncExternalVerifier
Definition: test/core/util/tls_utils.h:58
grpc_tls_identity_pairs_create
GRPCAPI grpc_tls_identity_pairs * grpc_tls_identity_pairs_create()
Definition: grpc_tls_certificate_distributor.cc:332
kH2TLSFeatureMask
static const uint32_t kH2TLSFeatureMask
Definition: h2_tls.cc:366
tls_utils.h
grpc_load_file
grpc_error_handle grpc_load_file(const char *filename, int add_null_terminator, grpc_slice *output)
Definition: load_file.cc:33
generate.env
env
Definition: generate.py:37
GRPC_STATUS_UNAUTHENTICATED
@ GRPC_STATUS_UNAUTHENTICATED
Definition: include/grpc/impl/codegen/status.h:72
memset
return memset(p, 0, total)
load_file.h
grpc_end2end_tests_pre_init
void grpc_end2end_tests_pre_init(void)
Definition: end2end_tests.cc:221
SecurityPrimitives::tls_version
enum SecurityPrimitives::TlsVersion tls_version
GRPC_ARG_STRING
@ GRPC_ARG_STRING
Definition: grpc_types.h:80
chttp2_create_fixture_hostname_verifier_cert_watcher
static grpc_end2end_test_fixture chttp2_create_fixture_hostname_verifier_cert_watcher(const grpc_channel_args *, const grpc_channel_args *)
Definition: h2_tls.cc:210
string.h
options
double_dict options[]
Definition: capstone_test.c:55
ind
Definition: bloaty/third_party/zlib/examples/gun.c:81
grpc_tls_credentials_options_set_certificate_verifier
void grpc_tls_credentials_options_set_certificate_verifier(grpc_tls_credentials_options *options, grpc_tls_certificate_verifier *verifier)
Definition: grpc_tls_credentials_options.cc:85
grpc_tls_identity_pairs
Definition: grpc_tls_certificate_distributor.h:38
grpc_core::StringViewFromSlice
absl::string_view StringViewFromSlice(const grpc_slice &slice)
Definition: slice_internal.h:93
SecurityPrimitives::VerifierType
VerifierType
Definition: h2_tls.cc:53
testing::internal::string
::std::string string
Definition: bloaty/third_party/protobuf/third_party/googletest/googletest/include/gtest/internal/gtest-port.h:881
grpc_process_auth_metadata_done_cb
void(* grpc_process_auth_metadata_done_cb)(void *user_data, const grpc_metadata *consumed_md, size_t num_consumed_md, const grpc_metadata *response_md, size_t num_response_md, grpc_status_code status, const char *error_details)
Definition: grpc_security.h:585
create_tls_server_credentials
static grpc_server_credentials * create_tls_server_credentials(fullstack_secure_fixture_data *ffd)
Definition: h2_tls.cc:308
TLS1_3
@ TLS1_3
Definition: grpc_security_constants.h:146
grpc_tls_certificate_provider_release
GRPCAPI void grpc_tls_certificate_provider_release(grpc_tls_certificate_provider *provider)
Definition: grpc_tls_certificate_provider.cc:477
FEATURE_MASK_SUPPORTS_PER_CALL_CREDENTIALS
#define FEATURE_MASK_SUPPORTS_PER_CALL_CREDENTIALS
Definition: end2end_tests.h:32
SecurityPrimitives::V_12
@ V_12
Definition: h2_tls.cc:58
grpc_server_create
GRPCAPI grpc_server * grpc_server_create(const grpc_channel_args *args, void *reserved)
Definition: src/core/lib/surface/server.cc:1456
grpc_tls_credentials_options_set_check_call_host
GRPCAPI void grpc_tls_credentials_options_set_check_call_host(grpc_tls_credentials_options *options, int check_call_host)
Definition: grpc_tls_credentials_options.cc:99
grpc_server_register_completion_queue
GRPCAPI void grpc_server_register_completion_queue(grpc_server *server, grpc_completion_queue *cq, void *reserved)
Definition: src/core/lib/surface/server.cc:1466
grpc_tls_identity_pairs_add_pair
GRPCAPI void grpc_tls_identity_pairs_add_pair(grpc_tls_identity_pairs *pairs, const char *private_key, const char *cert_chain)
Definition: grpc_tls_certificate_distributor.cc:336
env.h
SetCertificateVerifier
static void SetCertificateVerifier(fullstack_secure_fixture_data *ffd, SecurityPrimitives::VerifierType verifier_type)
Definition: h2_tls.cc:134
grpc_tls_credentials_create
grpc_channel_credentials * grpc_tls_credentials_create(grpc_tls_credentials_options *options)
Definition: tls_credentials.cc:146
GRPC_LOG_IF_ERROR
#define GRPC_LOG_IF_ERROR(what, error)
Definition: error.h:398
grpc_tls_credentials_options_watch_root_certs
GRPCAPI void grpc_tls_credentials_options_watch_root_certs(grpc_tls_credentials_options *options)
Definition: grpc_tls_credentials_options.cc:61
grpc_security.h
grpc_end2end_test_config
Definition: end2end_tests.h:53
chttp2_init_client
static void chttp2_init_client(grpc_end2end_test_fixture *f, const grpc_channel_args *client_args)
Definition: h2_tls.cc:328
SecurityPrimitives::STATIC_PROVIDER
@ STATIC_PROVIDER
Definition: h2_tls.cc:52
credentials.h
grpc_channel_args
Definition: grpc_types.h:132
chttp2_init_client_secure_fullstack
static void chttp2_init_client_secure_fullstack(grpc_end2end_test_fixture *f, const grpc_channel_args *client_args, grpc_channel_credentials *creds)
Definition: h2_tls.cc:252
grpc_server_credentials_set_auth_metadata_processor
GRPCAPI void grpc_server_credentials_set_auth_metadata_processor(grpc_server_credentials *creds, grpc_auth_metadata_processor processor)
Definition: credentials.cc:112
SecurityPrimitives::provider_type
enum SecurityPrimitives::ProviderType provider_type
FAIL_AUTH_CHECK_SERVER_ARG_NAME
#define FAIL_AUTH_CHECK_SERVER_ARG_NAME
Definition: end2end_tests.h:44
grpc_tls_server_credentials_create
grpc_server_credentials * grpc_tls_server_credentials_create(grpc_tls_credentials_options *options)
Definition: tls_credentials.cc:155
SecurityPrimitives::EXTERNAL_ASYNC_VERIFIER
@ EXTERNAL_ASYNC_VERIFIER
Definition: h2_tls.cc:55
fullstack_secure_fixture_data::check_call_host
bool check_call_host
Definition: h2_tls.cc:74
create_tls_channel_credentials
static grpc_channel_credentials * create_tls_channel_credentials(fullstack_secure_fixture_data *ffd)
Definition: h2_tls.cc:285
grpc_end2end_test_fixture
Definition: end2end_tests.h:46
uint32_t
unsigned int uint32_t
Definition: stdint-msvc2008.h:80
FEATURE_MASK_SUPPORTS_DELAYED_CONNECTION
#define FEATURE_MASK_SUPPORTS_DELAYED_CONNECTION
Definition: end2end_tests.h:28
chttp2_create_fixture_simple_fullstack
static grpc_end2end_test_fixture chttp2_create_fixture_simple_fullstack(const grpc_channel_args *, const grpc_channel_args *)
Definition: h2_tls.cc:175
string_util.h
grpc_metadata
Definition: grpc_types.h:537
autogen_x86imm.f
f
Definition: autogen_x86imm.py:9
GPR_ASSERT
#define GPR_ASSERT(x)
Definition: include/grpc/impl/codegen/log.h:94
GRPC_SSL_TARGET_NAME_OVERRIDE_ARG
#define GRPC_SSL_TARGET_NAME_OVERRIDE_ARG
Definition: grpc_types.h:278
grpc_server_credentials_release
GRPCAPI void grpc_server_credentials_release(grpc_server_credentials *creds)
Definition: credentials.cc:95
CA_CERT_PATH
#define CA_CERT_PATH
Definition: h2_tls.cc:45
grpc_server_add_http2_port
GRPCAPI int grpc_server_add_http2_port(grpc_server *server, const char *addr, grpc_server_credentials *creds)
Definition: chttp2_server.cc:1029
fullstack_secure_fixture_data::client_verifier
grpc_tls_certificate_verifier * client_verifier
Definition: h2_tls.cc:72
fullstack_secure_fixture_data
struct fullstack_secure_fixture_data fullstack_secure_fixture_data
grpc_core::JoinHostPort
std::string JoinHostPort(absl::string_view host, int port)
Definition: host_port.cc:32
tmpfile.h
grpc_channel_args_destroy
void grpc_channel_args_destroy(grpc_channel_args *a)
Definition: channel_args.cc:360
grpc_channel_args::num_args
size_t num_args
Definition: grpc_types.h:133
grpc_slice
Definition: include/grpc/impl/codegen/slice.h:65
grpc_core::testing::AsyncExternalVerifier
Definition: test/core/util/tls_utils.h:92
chttp2_create_fixture_async_verifier_cert_watcher
static grpc_end2end_test_fixture chttp2_create_fixture_async_verifier_cert_watcher(const grpc_channel_args *, const grpc_channel_args *)
Definition: h2_tls.cc:227
chttp2_tear_down_secure_fullstack
void chttp2_tear_down_secure_fullstack(grpc_end2end_test_fixture *f)
Definition: h2_tls.cc:278
grpc_tls_version
grpc_tls_version
Definition: grpc_security_constants.h:146
SecurityPrimitives::HOSTNAME_VERIFIER
@ HOSTNAME_VERIFIER
Definition: h2_tls.cc:56
grpc_server_destroy
GRPCAPI void grpc_server_destroy(grpc_server *server)
Definition: src/core/lib/surface/server.cc:1519
host_port.h
grpc_pick_unused_port_or_die
int grpc_pick_unused_port_or_die(void)
end2end_tests.h
chttp2_init_server_secure_fullstack
static void chttp2_init_server_secure_fullstack(grpc_end2end_test_fixture *f, const grpc_channel_args *server_args, grpc_server_credentials *server_creds)
Definition: h2_tls.cc:262
ssl_utils_config.h
SecurityPrimitives::TlsVersion
TlsVersion
Definition: h2_tls.cc:58
GPR_GLOBAL_CONFIG_SET
#define GPR_GLOBAL_CONFIG_SET(name, value)
Definition: global_config_generic.h:26
tests.unit._exit_scenarios.port
port
Definition: _exit_scenarios.py:179
SecurityPrimitives::V_13
@ V_13
Definition: h2_tls.cc:58
test_config.h
grpc_channel_credentials_release
GRPCAPI void grpc_channel_credentials_release(grpc_channel_credentials *creds)
Definition: credentials.cc:36
fullstack_secure_fixture_data::server_verifier
grpc_tls_certificate_verifier * server_verifier
Definition: h2_tls.cc:73
grpc_end2end_tests
void grpc_end2end_tests(int argc, char **argv, grpc_end2end_test_config config)
Definition: end2end_tests.cc:321
grpc_server_credentials
Definition: src/core/lib/security/credentials/credentials.h:259
fullstack_secure_fixture_data::server_provider
grpc_tls_certificate_provider * server_provider
Definition: h2_tls.cc:71
fullstack_secure_fixture_data::~fullstack_secure_fixture_data
~fullstack_secure_fixture_data()
Definition: h2_tls.cc:62
SERVER_CERT_PATH
#define SERVER_CERT_PATH
Definition: h2_tls.cc:46
fullstack_secure_fixture_data::tls_version
grpc_tls_version tls_version
Definition: h2_oauth2.cc:45
grpc_tls_certificate_verifier_host_name_create
grpc_tls_certificate_verifier * grpc_tls_certificate_verifier_host_name_create()
Definition: grpc_tls_certificate_verifier.cc:230
grpc_channel_create
GRPCAPI grpc_channel * grpc_channel_create(const char *target, grpc_channel_credentials *creds, const grpc_channel_args *args)
Definition: chttp2_connector.cc:366
grpc_tls_credentials_options.h
grpc_tls_credentials_options_set_cert_request_type
GRPCAPI void grpc_tls_credentials_options_set_cert_request_type(grpc_tls_credentials_options *options, grpc_ssl_client_certificate_request_type type)
Definition: grpc_tls_credentials_options.cc:38
grpc_tls_credentials_options_create
GRPCAPI grpc_tls_credentials_options * grpc_tls_credentials_options_create(void)
Definition: grpc_tls_credentials_options.cc:33
grpc_tls_credentials_options_set_verify_server_cert
GRPCAPI void grpc_tls_credentials_options_set_verify_server_cert(grpc_tls_credentials_options *options, int verify_server_cert)
Definition: grpc_tls_credentials_options.cc:45
TLS1_2
@ TLS1_2
Definition: grpc_security_constants.h:146
SecurityPrimitives::verifier_type
enum SecurityPrimitives::VerifierType verifier_type
grpc_tls_certificate_verifier_external_create
grpc_tls_certificate_verifier * grpc_tls_certificate_verifier_external_create(grpc_tls_certificate_verifier_external *external_verifier)
Definition: grpc_tls_certificate_verifier.cc:218
alloc.h
private_key
Definition: hrss.c:1885
grpc::testing::TestEnvironment
Definition: test/core/util/test_config.h:54
grpc_tls_credentials_options
Definition: grpc_tls_credentials_options.h:39
grpc_arg::key
char * key
Definition: grpc_types.h:105
fail_server_auth_check
static int fail_server_auth_check(const grpc_channel_args *server_args)
Definition: h2_tls.cc:342
thd.h
chttp2_init_server
static void chttp2_init_server(grpc_end2end_test_fixture *f, const grpc_channel_args *server_args)
Definition: h2_tls.cc:354
grpc_auth_metadata_processor
Definition: grpc_security.h:591
grpc_tls_credentials_options_watch_identity_key_cert_pairs
GRPCAPI void grpc_tls_credentials_options_watch_identity_key_cert_pairs(grpc_tls_credentials_options *options)
Definition: grpc_tls_credentials_options.cc:73
fullstack_secure_fixture_data
Definition: h2_fakesec.cc:32
state
Definition: bloaty/third_party/zlib/contrib/blast/blast.c:41
grpc_tls_certificate_verifier_release
void grpc_tls_certificate_verifier_release(grpc_tls_certificate_verifier *verifier)
Definition: grpc_tls_certificate_verifier.cc:235
grpc_tls_certificate_verifier
Definition: grpc_tls_certificate_verifier.h:38
SecurityPrimitives::ProviderType
ProviderType
Definition: h2_tls.cc:52
channel_args.h
SecurityPrimitives::EXTERNAL_SYNC_VERIFIER
@ EXTERNAL_SYNC_VERIFIER
Definition: h2_tls.cc:54
chttp2_create_fixture_async_verifier
static grpc_end2end_test_fixture chttp2_create_fixture_async_verifier(const grpc_channel_args *, const grpc_channel_args *)
Definition: h2_tls.cc:192
configs
static grpc_end2end_test_config configs[]
Definition: h2_tls.cc:372
SetCertificateProvider
static void SetCertificateProvider(fullstack_secure_fixture_data *ffd, SecurityPrimitives::ProviderType provider_type)
Definition: h2_tls.cc:91
SetTlsVersion
static void SetTlsVersion(fullstack_secure_fixture_data *ffd, SecurityPrimitives::TlsVersion tls_version)
Definition: h2_tls.cc:77
grpc_tls_certificate_provider
Definition: grpc_tls_certificate_provider.h:53
SecurityPrimitives
Definition: h2_tls.cc:51
GRPC_SSL_REQUEST_AND_REQUIRE_CLIENT_CERTIFICATE_AND_VERIFY
@ GRPC_SSL_REQUEST_AND_REQUIRE_CLIENT_CERTIFICATE_AND_VERIFY
Definition: grpc_security_constants.h:125
grpc_completion_queue_create_for_next
GRPCAPI grpc_completion_queue * grpc_completion_queue_create_for_next(void *reserved)
Definition: completion_queue_factory.cc:62
grpc_tls_certificate_provider_file_watcher_create
GRPCAPI grpc_tls_certificate_provider * grpc_tls_certificate_provider_file_watcher_create(const char *private_key_path, const char *identity_certificate_path, const char *root_cert_path, unsigned int refresh_interval_sec)
Definition: grpc_tls_certificate_provider.cc:467
absl::InlinedVector
Definition: abseil-cpp/absl/container/inlined_vector.h:69
grpc_init
GRPCAPI void grpc_init(void)
Definition: init.cc:146
grpc_server_start
GRPCAPI void grpc_server_start(grpc_server *server)
Definition: src/core/lib/surface/server.cc:1497
ThreadList
absl::InlinedVector< grpc_core::Thread, 1 > ThreadList
Definition: h2_tls.cc:49
process_auth_failure
static void process_auth_failure(void *state, grpc_auth_context *, const grpc_metadata *, size_t, grpc_process_auth_metadata_done_cb cb, void *user_data)
Definition: h2_tls.cc:243
SecurityPrimitives::FILE_PROVIDER
@ FILE_PROVIDER
Definition: h2_tls.cc:52
grpc_tls_certificate_provider_static_data_create
GRPCAPI grpc_tls_certificate_provider * grpc_tls_certificate_provider_static_data_create(const char *root_certificate, grpc_tls_identity_pairs *pem_key_cert_pairs)
Definition: grpc_tls_certificate_provider.cc:449
grpc_channel_args::args
grpc_arg * args
Definition: grpc_types.h:134
grpc_shutdown
GRPCAPI void grpc_shutdown(void)
Definition: init.cc:209
grpc_channel_credentials
Definition: src/core/lib/security/credentials/credentials.h:96
SERVER_KEY_PATH
#define SERVER_KEY_PATH
Definition: h2_tls.cc:47
cb
OPENSSL_EXPORT pem_password_cb * cb
Definition: pem.h:351
grpc_channel_args_copy_and_add
grpc_channel_args * grpc_channel_args_copy_and_add(const grpc_channel_args *src, const grpc_arg *to_add, size_t num_to_add)
Definition: channel_args.cc:224
i
uint64_t i
Definition: abseil-cpp/absl/container/btree_benchmark.cc:230
FEATURE_MASK_SUPPORTS_CLIENT_CHANNEL
#define FEATURE_MASK_SUPPORTS_CLIENT_CHANNEL
Definition: end2end_tests.h:37


grpc
Author(s):
autogenerated on Thu Mar 13 2025 03:00:10