h2_ssl_cred_reload.cc
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015 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 <grpc/support/alloc.h>
23 #include <grpc/support/log.h>
24 
34 #include "test/core/util/port.h"
36 
37 #define CA_CERT_PATH "src/core/tsi/test_creds/ca.pem"
38 #define SERVER_CERT_PATH "src/core/tsi/test_creds/server1.pem"
39 #define SERVER_KEY_PATH "src/core/tsi/test_creds/server1.key"
40 
45 };
46 
49  void* user_data, grpc_ssl_server_certificate_config** config) {
50  if (config == nullptr) {
52  }
54  static_cast<fullstack_secure_fixture_data*>(user_data);
55  if (!ffd->server_credential_reloaded) {
56  grpc_slice ca_slice, cert_slice, key_slice;
57  GPR_ASSERT(GRPC_LOG_IF_ERROR("load_file",
58  grpc_load_file(CA_CERT_PATH, 1, &ca_slice)));
60  "load_file", grpc_load_file(SERVER_CERT_PATH, 1, &cert_slice)));
62  "load_file", grpc_load_file(SERVER_KEY_PATH, 1, &key_slice)));
63  const char* ca_cert =
64  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(ca_slice);
65  const char* server_cert =
66  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(cert_slice);
67  const char* server_key =
68  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(key_slice);
69  grpc_ssl_pem_key_cert_pair pem_key_cert_pair = {server_key, server_cert};
71  &pem_key_cert_pair, 1);
72  grpc_slice_unref(cert_slice);
73  grpc_slice_unref(key_slice);
74  grpc_slice_unref(ca_slice);
75  ffd->server_credential_reloaded = true;
77  } else {
79  }
80 }
81 
83  const grpc_channel_args* /*client_args*/,
84  const grpc_channel_args* /*server_args*/, grpc_tls_version tls_version) {
88  memset(&f, 0, sizeof(f));
89  ffd->localaddr = grpc_core::JoinHostPort("localhost", port);
90  ffd->tls_version = tls_version;
91 
92  f.fixture_data = ffd;
94 
95  return f;
96 }
97 
99  const grpc_channel_args* client_args,
100  const grpc_channel_args* server_args) {
101  return chttp2_create_fixture_secure_fullstack(client_args, server_args,
103 }
104 
106  const grpc_channel_args* client_args,
107  const grpc_channel_args* server_args) {
108  return chttp2_create_fixture_secure_fullstack(client_args, server_args,
110 }
111 
112 static void process_auth_failure(void* state, grpc_auth_context* /*ctx*/,
113  const grpc_metadata* /*md*/,
114  size_t /*md_count*/,
116  void* user_data) {
117  GPR_ASSERT(state == nullptr);
118  cb(user_data, nullptr, 0, nullptr, 0, GRPC_STATUS_UNAUTHENTICATED, nullptr);
119 }
120 
122  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args,
123  grpc_channel_credentials* creds) {
125  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
126  f->client = grpc_channel_create(ffd->localaddr.c_str(), creds, client_args);
127  GPR_ASSERT(f->client != nullptr);
129 }
130 
132  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args,
133  grpc_server_credentials* server_creds) {
135  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
136  if (f->server) {
137  grpc_server_destroy(f->server);
138  }
139  ffd->server_credential_reloaded = false;
140  f->server = grpc_server_create(server_args, nullptr);
141  grpc_server_register_completion_queue(f->server, f->cq, nullptr);
142  GPR_ASSERT(grpc_server_add_http2_port(f->server, ffd->localaddr.c_str(),
143  server_creds));
144  grpc_server_credentials_release(server_creds);
145  grpc_server_start(f->server);
146 }
147 
150  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
151  delete ffd;
152 }
153 
155  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args) {
156  grpc_channel_credentials* ssl_creds =
157  grpc_ssl_credentials_create(nullptr, nullptr, nullptr, nullptr);
158  if (f != nullptr && ssl_creds != nullptr) {
159  // Set the min and max TLS version.
160  grpc_ssl_credentials* creds =
161  reinterpret_cast<grpc_ssl_credentials*>(ssl_creds);
163  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
164  creds->set_min_tls_version(ffd->tls_version);
165  creds->set_max_tls_version(ffd->tls_version);
166  }
167  grpc_arg ssl_name_override = {
169  const_cast<char*>(GRPC_SSL_TARGET_NAME_OVERRIDE_ARG),
170  {const_cast<char*>("foo.test.google.fr")}};
171  const grpc_channel_args* new_client_args =
172  grpc_channel_args_copy_and_add(client_args, &ssl_name_override, 1);
173  chttp2_init_client_secure_fullstack(f, new_client_args, ssl_creds);
174  grpc_channel_args_destroy(new_client_args);
175 }
176 
177 static int fail_server_auth_check(const grpc_channel_args* server_args) {
178  size_t i;
179  if (server_args == nullptr) return 0;
180  for (i = 0; i < server_args->num_args; i++) {
181  if (strcmp(server_args->args[i].key, FAIL_AUTH_CHECK_SERVER_ARG_NAME) ==
182  0) {
183  return 1;
184  }
185  }
186  return 0;
187 }
188 
190  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args) {
195  grpc_server_credentials* ssl_creds =
197  if (f != nullptr && ssl_creds != nullptr) {
198  // Set the min and max TLS version.
200  reinterpret_cast<grpc_ssl_server_credentials*>(ssl_creds);
202  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
203  creds->set_min_tls_version(ffd->tls_version);
204  creds->set_max_tls_version(ffd->tls_version);
205  }
206  if (fail_server_auth_check(server_args)) {
208  nullptr};
210  }
211  chttp2_init_server_secure_fullstack(f, server_args, ssl_creds);
212 }
213 
214 /* All test configurations */
215 
217  {"chttp2/simple_ssl_fullstack_tls1_2",
222  "foo.test.google.fr", chttp2_create_fixture_secure_fullstack_tls1_2,
226  {"chttp2/simple_ssl_fullstack_tls1_3",
232  "foo.test.google.fr", chttp2_create_fixture_secure_fullstack_tls1_3,
236 };
237 
238 int main(int argc, char** argv) {
239  size_t i;
240 
241  grpc::testing::TestEnvironment env(&argc, argv);
243  GPR_GLOBAL_CONFIG_SET(grpc_default_ssl_roots_file_path, CA_CERT_PATH);
244 
245  grpc_init();
246 
247  for (i = 0; i < sizeof(configs) / sizeof(*configs); i++) {
248  grpc_end2end_tests(argc, argv, configs[i]);
249  }
250 
251  grpc_shutdown();
252 
253  return 0;
254 }
grpc_arg
Definition: grpc_types.h:103
fail_server_auth_check
static int fail_server_auth_check(const grpc_channel_args *server_args)
Definition: h2_ssl_cred_reload.cc:177
grpc_slice_unref
GPRAPI void grpc_slice_unref(grpc_slice s)
Definition: slice_api.cc:32
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
grpc_ssl_credentials
Definition: ssl_credentials.h:39
fullstack_secure_fixture_data::localaddr
std::string localaddr
Definition: h2_fakesec.cc:33
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
GRPC_ARG_STRING
@ GRPC_ARG_STRING
Definition: grpc_types.h:80
SERVER_CERT_PATH
#define SERVER_CERT_PATH
Definition: h2_ssl_cred_reload.cc:38
SERVER_KEY_PATH
#define SERVER_KEY_PATH
Definition: h2_ssl_cred_reload.cc:39
grpc_ssl_certificate_config_reload_status
grpc_ssl_certificate_config_reload_status
Definition: grpc_security_constants.h:73
string.h
options
double_dict options[]
Definition: capstone_test.c:55
grpc_ssl_server_credentials::set_min_tls_version
void set_min_tls_version(grpc_tls_version min_tls_version)
Definition: ssl_credentials.cc:231
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
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_ssl_cred_reload.cc:131
TLS1_3
@ TLS1_3
Definition: grpc_security_constants.h:146
ssl_server_certificate_config_callback
static grpc_ssl_certificate_config_reload_status ssl_server_certificate_config_callback(void *user_data, grpc_ssl_server_certificate_config **config)
Definition: h2_ssl_cred_reload.cc:48
FEATURE_MASK_SUPPORTS_PER_CALL_CREDENTIALS
#define FEATURE_MASK_SUPPORTS_PER_CALL_CREDENTIALS
Definition: end2end_tests.h:32
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_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_LOG_IF_ERROR
#define GRPC_LOG_IF_ERROR(what, error)
Definition: error.h:398
CA_CERT_PATH
#define CA_CERT_PATH
Definition: h2_ssl_cred_reload.cc:37
grpc_ssl_server_certificate_config_create
GRPCAPI grpc_ssl_server_certificate_config * grpc_ssl_server_certificate_config_create(const char *pem_root_certs, const grpc_ssl_pem_key_cert_pair *pem_key_cert_pairs, size_t num_key_cert_pairs)
Definition: ssl_credentials.cc:241
chttp2_init_client_simple_ssl_secure_fullstack
static void chttp2_init_client_simple_ssl_secure_fullstack(grpc_end2end_test_fixture *f, const grpc_channel_args *client_args)
Definition: h2_ssl_cred_reload.cc:154
grpc_end2end_test_config
Definition: end2end_tests.h:53
grpc_ssl_server_credentials_options
Definition: ssl_credentials.cc:167
credentials.h
grpc_channel_args
Definition: grpc_types.h:132
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
FAIL_AUTH_CHECK_SERVER_ARG_NAME
#define FAIL_AUTH_CHECK_SERVER_ARG_NAME
Definition: end2end_tests.h:44
grpc_ssl_credentials_create
GRPCAPI grpc_channel_credentials * grpc_ssl_credentials_create(const char *pem_root_certs, grpc_ssl_pem_key_cert_pair *pem_key_cert_pair, const verify_peer_options *verify_options, void *reserved)
Definition: ssl_credentials.cc:132
grpc_end2end_test_fixture
Definition: end2end_tests.h:46
FEATURE_MASK_SUPPORTS_DELAYED_CONNECTION
#define FEATURE_MASK_SUPPORTS_DELAYED_CONNECTION
Definition: end2end_tests.h:28
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
grpc_ssl_credentials::set_min_tls_version
void set_min_tls_version(grpc_tls_version min_tls_version)
Definition: ssl_credentials.cc:120
GRPC_SSL_CERTIFICATE_CONFIG_RELOAD_UNCHANGED
@ GRPC_SSL_CERTIFICATE_CONFIG_RELOAD_UNCHANGED
Definition: grpc_security_constants.h:74
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
struct fullstack_secure_fixture_data fullstack_secure_fixture_data
GRPC_SSL_CERTIFICATE_CONFIG_RELOAD_NEW
@ GRPC_SSL_CERTIFICATE_CONFIG_RELOAD_NEW
Definition: grpc_security_constants.h:75
chttp2_create_fixture_secure_fullstack_tls1_2
static grpc_end2end_test_fixture chttp2_create_fixture_secure_fullstack_tls1_2(const grpc_channel_args *client_args, const grpc_channel_args *server_args)
Definition: h2_ssl_cred_reload.cc:98
chttp2_init_server_simple_ssl_secure_fullstack
static void chttp2_init_server_simple_ssl_secure_fullstack(grpc_end2end_test_fixture *f, const grpc_channel_args *server_args)
Definition: h2_ssl_cred_reload.cc:189
GRPC_SSL_CERTIFICATE_CONFIG_RELOAD_FAIL
@ GRPC_SSL_CERTIFICATE_CONFIG_RELOAD_FAIL
Definition: grpc_security_constants.h:76
grpc_core::JoinHostPort
std::string JoinHostPort(absl::string_view host, int port)
Definition: host_port.cc:32
tmpfile.h
GRPC_SLICE_START_PTR
#define GRPC_SLICE_START_PTR(slice)
Definition: include/grpc/impl/codegen/slice.h:101
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_tls_version
grpc_tls_version
Definition: grpc_security_constants.h:146
FEATURE_MASK_DOES_NOT_SUPPORT_CLIENT_HANDSHAKE_COMPLETE_FIRST
#define FEATURE_MASK_DOES_NOT_SUPPORT_CLIENT_HANDSHAKE_COMPLETE_FIRST
Definition: end2end_tests.h:42
fullstack_secure_fixture_data::server_credential_reloaded
bool server_credential_reloaded
Definition: h2_ssl_cred_reload.cc:44
grpc_server_destroy
GRPCAPI void grpc_server_destroy(grpc_server *server)
Definition: src/core/lib/surface/server.cc:1519
grpc_ssl_credentials::set_max_tls_version
void set_max_tls_version(grpc_tls_version max_tls_version)
Definition: ssl_credentials.cc:125
host_port.h
grpc_pick_unused_port_or_die
int grpc_pick_unused_port_or_die(void)
end2end_tests.h
grpc_ssl_server_certificate_config
Definition: ssl_credentials.h:76
ssl_utils_config.h
GPR_GLOBAL_CONFIG_SET
#define GPR_GLOBAL_CONFIG_SET(name, value)
Definition: global_config_generic.h:26
grpc_ssl_server_credentials
Definition: ssl_credentials.h:87
configs
static grpc_end2end_test_config configs[]
Definition: h2_ssl_cred_reload.cc:216
tests.unit._exit_scenarios.port
port
Definition: _exit_scenarios.py:179
test_config.h
chttp2_create_fixture_secure_fullstack
static grpc_end2end_test_fixture chttp2_create_fixture_secure_fullstack(const grpc_channel_args *, const grpc_channel_args *, grpc_tls_version tls_version)
Definition: h2_ssl_cred_reload.cc:82
grpc_channel_credentials_release
GRPCAPI void grpc_channel_credentials_release(grpc_channel_credentials *creds)
Definition: credentials.cc:36
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::tls_version
grpc_tls_version tls_version
Definition: h2_oauth2.cc:45
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
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_ssl_cred_reload.cc:121
main
int main(int argc, char **argv)
Definition: h2_ssl_cred_reload.cc:238
TLS1_2
@ TLS1_2
Definition: grpc_security_constants.h:146
grpc_ssl_server_credentials_create_options_using_config_fetcher
GRPCAPI grpc_ssl_server_credentials_options * grpc_ssl_server_credentials_create_options_using_config_fetcher(grpc_ssl_client_certificate_request_type client_certificate_request, grpc_ssl_server_certificate_config_callback cb, void *user_data)
Definition: ssl_credentials.cc:296
chttp2_tear_down_secure_fullstack
void chttp2_tear_down_secure_fullstack(grpc_end2end_test_fixture *f)
Definition: h2_ssl_cred_reload.cc:148
GRPC_SSL_DONT_REQUEST_CLIENT_CERTIFICATE
@ GRPC_SSL_DONT_REQUEST_CLIENT_CERTIFICATE
Definition: grpc_security_constants.h:84
alloc.h
grpc::testing::TestEnvironment
Definition: test/core/util/test_config.h:54
grpc_arg::key
char * key
Definition: grpc_types.h:105
grpc_auth_metadata_processor
Definition: grpc_security.h:591
fullstack_secure_fixture_data
Definition: h2_fakesec.cc:32
state
Definition: bloaty/third_party/zlib/contrib/blast/blast.c:41
config_s
Definition: bloaty/third_party/zlib/deflate.c:120
channel_args.h
grpc_ssl_server_credentials_create_with_options
GRPCAPI grpc_server_credentials * grpc_ssl_server_credentials_create_with_options(grpc_ssl_server_credentials_options *options)
Definition: ssl_credentials.cc:354
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_ssl_server_credentials::set_max_tls_version
void set_max_tls_version(grpc_tls_version max_tls_version)
Definition: ssl_credentials.cc:236
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
ssl_credentials.h
grpc_channel_args::args
grpc_arg * args
Definition: grpc_types.h:134
grpc_shutdown
GRPCAPI void grpc_shutdown(void)
Definition: init.cc:209
grpc_ssl_pem_key_cert_pair
Definition: grpc_security.h:173
grpc_channel_credentials
Definition: src/core/lib/security/credentials/credentials.h:96
cb
OPENSSL_EXPORT pem_password_cb * cb
Definition: pem.h:351
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_ssl_cred_reload.cc:112
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
chttp2_create_fixture_secure_fullstack_tls1_3
static grpc_end2end_test_fixture chttp2_create_fixture_secure_fullstack_tls1_3(const grpc_channel_args *client_args, const grpc_channel_args *server_args)
Definition: h2_ssl_cred_reload.cc:105


grpc
Author(s):
autogenerated on Fri May 16 2025 02:59:00