h2_ssl.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 
44 };
45 
47  const grpc_channel_args* /*client_args*/,
48  const grpc_channel_args* /*server_args*/, grpc_tls_version tls_version) {
52  memset(&f, 0, sizeof(f));
53 
54  ffd->localaddr = grpc_core::JoinHostPort("localhost", port);
55  ffd->tls_version = tls_version;
56 
57  f.fixture_data = ffd;
59 
60  return f;
61 }
62 
64  const grpc_channel_args* client_args,
65  const grpc_channel_args* server_args) {
66  return chttp2_create_fixture_secure_fullstack(client_args, server_args,
68 }
69 
71  const grpc_channel_args* client_args,
72  const grpc_channel_args* server_args) {
73  return chttp2_create_fixture_secure_fullstack(client_args, server_args,
75 }
76 
77 static void process_auth_failure(void* state, grpc_auth_context* /*ctx*/,
78  const grpc_metadata* /*md*/,
79  size_t /*md_count*/,
81  void* user_data) {
82  GPR_ASSERT(state == nullptr);
83  cb(user_data, nullptr, 0, nullptr, 0, GRPC_STATUS_UNAUTHENTICATED, nullptr);
84 }
85 
87  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args,
88  grpc_channel_credentials* creds) {
90  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
91  f->client = grpc_channel_create(ffd->localaddr.c_str(), creds, client_args);
92  GPR_ASSERT(f->client != nullptr);
94 }
95 
97  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args,
98  grpc_server_credentials* server_creds) {
100  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
101  if (f->server) {
102  grpc_server_destroy(f->server);
103  }
104  f->server = grpc_server_create(server_args, nullptr);
105  grpc_server_register_completion_queue(f->server, f->cq, nullptr);
106  GPR_ASSERT(grpc_server_add_http2_port(f->server, ffd->localaddr.c_str(),
107  server_creds));
108  grpc_server_credentials_release(server_creds);
109  grpc_server_start(f->server);
110 }
111 
114  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
115  delete ffd;
116 }
117 
119  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args) {
120  grpc_channel_credentials* ssl_creds =
121  grpc_ssl_credentials_create(nullptr, nullptr, nullptr, nullptr);
122  if (f != nullptr && ssl_creds != nullptr) {
123  // Set the min and max TLS version.
124  grpc_ssl_credentials* creds =
125  reinterpret_cast<grpc_ssl_credentials*>(ssl_creds);
127  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
128  creds->set_min_tls_version(ffd->tls_version);
129  creds->set_max_tls_version(ffd->tls_version);
130  }
131  grpc_arg ssl_name_override = {
133  const_cast<char*>(GRPC_SSL_TARGET_NAME_OVERRIDE_ARG),
134  {const_cast<char*>("foo.test.google.fr")}};
135  const grpc_channel_args* new_client_args =
136  grpc_channel_args_copy_and_add(client_args, &ssl_name_override, 1);
137  chttp2_init_client_secure_fullstack(f, new_client_args, ssl_creds);
138  grpc_channel_args_destroy(new_client_args);
139 }
140 
141 static int fail_server_auth_check(const grpc_channel_args* server_args) {
142  size_t i;
143  if (server_args == nullptr) return 0;
144  for (i = 0; i < server_args->num_args; i++) {
145  if (strcmp(server_args->args[i].key, FAIL_AUTH_CHECK_SERVER_ARG_NAME) ==
146  0) {
147  return 1;
148  }
149  }
150  return 0;
151 }
152 
154  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args) {
155  grpc_slice cert_slice, key_slice;
157  "load_file", grpc_load_file(SERVER_CERT_PATH, 1, &cert_slice)));
158  GPR_ASSERT(GRPC_LOG_IF_ERROR("load_file",
159  grpc_load_file(SERVER_KEY_PATH, 1, &key_slice)));
160  const char* server_cert =
161  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(cert_slice);
162  const char* server_key =
163  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(key_slice);
164  grpc_ssl_pem_key_cert_pair pem_key_cert_pair = {server_key, server_cert};
166  nullptr, &pem_key_cert_pair, 1, 0, nullptr);
167  if (f != nullptr && ssl_creds != nullptr) {
168  // Set the min and max TLS version.
170  reinterpret_cast<grpc_ssl_server_credentials*>(ssl_creds);
172  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
173  creds->set_min_tls_version(ffd->tls_version);
174  creds->set_max_tls_version(ffd->tls_version);
175  }
176  grpc_slice_unref(cert_slice);
177  grpc_slice_unref(key_slice);
178  if (fail_server_auth_check(server_args)) {
180  nullptr};
182  }
183  chttp2_init_server_secure_fullstack(f, server_args, ssl_creds);
184 }
185 
186 /* All test configurations */
187 
189  {"chttp2/simple_ssl_fullstack_tls1_2",
194  "foo.test.google.fr", chttp2_create_fixture_secure_fullstack_tls1_2,
198  {"chttp2/simple_ssl_fullstack_tls1_3",
204  "foo.test.google.fr", chttp2_create_fixture_secure_fullstack_tls1_3,
208 };
209 
210 int main(int argc, char** argv) {
211  size_t i;
212  grpc::testing::TestEnvironment env(&argc, argv);
214  GPR_GLOBAL_CONFIG_SET(grpc_default_ssl_roots_file_path, CA_CERT_PATH);
215 
216  grpc_init();
217 
218  for (i = 0; i < sizeof(configs) / sizeof(*configs); i++) {
219  grpc_end2end_tests(argc, argv, configs[i]);
220  }
221 
222  grpc_shutdown();
223  return 0;
224 }
grpc_arg
Definition: grpc_types.h:103
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
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.cc:86
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
fail_server_auth_check
static int fail_server_auth_check(const grpc_channel_args *server_args)
Definition: h2_ssl.cc:141
string.h
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
TLS1_3
@ TLS1_3
Definition: grpc_security_constants.h:146
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
grpc_end2end_test_config
Definition: end2end_tests.h:53
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_ssl_server_credentials_create
GRPCAPI grpc_server_credentials * grpc_ssl_server_credentials_create(const char *pem_root_certs, grpc_ssl_pem_key_cert_pair *pem_key_cert_pairs, size_t num_key_cert_pairs, int force_client_auth, void *reserved)
Definition: ssl_credentials.cc:319
SERVER_CERT_PATH
#define SERVER_CERT_PATH
Definition: h2_ssl.cc:38
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_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
chttp2_tear_down_secure_fullstack
void chttp2_tear_down_secure_fullstack(grpc_end2end_test_fixture *f)
Definition: h2_ssl.cc:112
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
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.cc:63
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
ssl_utils_config.h
main
int main(int argc, char **argv)
Definition: h2_ssl.cc:210
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.cc:70
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
tests.unit._exit_scenarios.port
port
Definition: _exit_scenarios.py:179
test_config.h
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_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.cc:96
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.cc:153
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.cc:77
TLS1_2
@ TLS1_2
Definition: grpc_security_constants.h:146
CA_CERT_PATH
#define CA_CERT_PATH
Definition: h2_ssl.cc:37
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
channel_args.h
SERVER_KEY_PATH
#define SERVER_KEY_PATH
Definition: h2_ssl.cc:39
configs
static grpc_end2end_test_config configs[]
Definition: h2_ssl.cc:188
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
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.cc:118
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.cc:46
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
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