h2_ssl_proxy.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 
33 #include "test/core/util/port.h"
35 
36 #define CA_CERT_PATH "src/core/tsi/test_creds/ca.pem"
37 #define SERVER_CERT_PATH "src/core/tsi/test_creds/server1.pem"
38 #define SERVER_KEY_PATH "src/core/tsi/test_creds/server1.key"
39 
40 typedef struct fullstack_secure_fixture_data {
43 
44 static grpc_server* create_proxy_server(const char* port,
45  const grpc_channel_args* server_args) {
46  grpc_server* s = grpc_server_create(server_args, nullptr);
47  grpc_slice cert_slice, key_slice;
49  "load_file", grpc_load_file(SERVER_CERT_PATH, 1, &cert_slice)));
50  GPR_ASSERT(GRPC_LOG_IF_ERROR("load_file",
51  grpc_load_file(SERVER_KEY_PATH, 1, &key_slice)));
52  const char* server_cert =
53  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(cert_slice);
54  const char* server_key =
55  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(key_slice);
56  grpc_ssl_pem_key_cert_pair pem_key_cert_pair = {server_key, server_cert};
58  nullptr, &pem_key_cert_pair, 1, 0, nullptr);
59  grpc_slice_unref(cert_slice);
60  grpc_slice_unref(key_slice);
63  return s;
64 }
65 
67  const grpc_channel_args* client_args) {
69  grpc_channel_credentials* ssl_creds =
70  grpc_ssl_credentials_create(nullptr, nullptr, nullptr, nullptr);
71  grpc_arg ssl_name_override = {
73  const_cast<char*>(GRPC_SSL_TARGET_NAME_OVERRIDE_ARG),
74  {const_cast<char*>("foo.test.google.fr")}};
75  const grpc_channel_args* new_client_args =
76  grpc_channel_args_copy_and_add(client_args, &ssl_name_override, 1);
77  channel = grpc_channel_create(target, ssl_creds, new_client_args);
79  {
81  grpc_channel_args_destroy(new_client_args);
82  }
83  return channel;
84 }
85 
88 
90  const grpc_channel_args* client_args,
91  const grpc_channel_args* server_args) {
94  static_cast<fullstack_secure_fixture_data*>(
96  memset(&f, 0, sizeof(f));
97 
98  ffd->proxy = grpc_end2end_proxy_create(&proxy_def, client_args, server_args);
99 
100  f.fixture_data = ffd;
102 
103  return f;
104 }
105 
106 static void process_auth_failure(void* state, grpc_auth_context* /*ctx*/,
107  const grpc_metadata* /*md*/,
108  size_t /*md_count*/,
110  void* user_data) {
111  GPR_ASSERT(state == nullptr);
112  cb(user_data, nullptr, 0, nullptr, 0, GRPC_STATUS_UNAUTHENTICATED, nullptr);
113 }
114 
116  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args,
117  grpc_channel_credentials* creds) {
119  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
120  f->client = grpc_channel_create(
121  grpc_end2end_proxy_get_client_target(ffd->proxy), creds, client_args);
122  GPR_ASSERT(f->client != nullptr);
124 }
125 
127  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args,
128  grpc_server_credentials* server_creds) {
130  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
131  if (f->server) {
132  grpc_server_destroy(f->server);
133  }
134  f->server = grpc_server_create(server_args, nullptr);
135  grpc_server_register_completion_queue(f->server, f->cq, nullptr);
137  f->server, grpc_end2end_proxy_get_server_port(ffd->proxy), server_creds));
138  grpc_server_credentials_release(server_creds);
139  grpc_server_start(f->server);
140 }
141 
144  static_cast<fullstack_secure_fixture_data*>(f->fixture_data);
146  gpr_free(ffd);
147 }
148 
150  grpc_end2end_test_fixture* f, const grpc_channel_args* client_args) {
151  grpc_channel_credentials* ssl_creds =
152  grpc_ssl_credentials_create(nullptr, nullptr, nullptr, nullptr);
153  grpc_arg ssl_name_override = {
155  const_cast<char*>(GRPC_SSL_TARGET_NAME_OVERRIDE_ARG),
156  {const_cast<char*>("foo.test.google.fr")}};
157  const grpc_channel_args* new_client_args =
158  grpc_channel_args_copy_and_add(client_args, &ssl_name_override, 1);
159  chttp2_init_client_secure_fullstack(f, new_client_args, ssl_creds);
160  {
162  grpc_channel_args_destroy(new_client_args);
163  }
164 }
165 
166 static int fail_server_auth_check(const grpc_channel_args* server_args) {
167  size_t i;
168  if (server_args == nullptr) return 0;
169  for (i = 0; i < server_args->num_args; i++) {
170  if (strcmp(server_args->args[i].key, FAIL_AUTH_CHECK_SERVER_ARG_NAME) ==
171  0) {
172  return 1;
173  }
174  }
175  return 0;
176 }
177 
179  grpc_end2end_test_fixture* f, const grpc_channel_args* server_args) {
180  grpc_slice cert_slice, key_slice;
182  "load_file", grpc_load_file(SERVER_CERT_PATH, 1, &cert_slice)));
183  GPR_ASSERT(GRPC_LOG_IF_ERROR("load_file",
184  grpc_load_file(SERVER_KEY_PATH, 1, &key_slice)));
185  const char* server_cert =
186  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(cert_slice);
187  const char* server_key =
188  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(key_slice);
189  grpc_ssl_pem_key_cert_pair pem_key_cert_pair = {server_key, server_cert};
191  nullptr, &pem_key_cert_pair, 1, 0, nullptr);
192  grpc_slice_unref(cert_slice);
193  grpc_slice_unref(key_slice);
194  if (fail_server_auth_check(server_args)) {
196  nullptr};
198  }
199  chttp2_init_server_secure_fullstack(f, server_args, ssl_creds);
200 }
201 
202 /* All test configurations */
203 
205  {"chttp2/simple_ssl_fullstack",
211  "foo.test.google.fr", chttp2_create_fixture_secure_fullstack,
215 };
216 
217 int main(int argc, char** argv) {
218  size_t i;
219 
220  grpc::testing::TestEnvironment env(&argc, argv);
222  GPR_GLOBAL_CONFIG_SET(grpc_default_ssl_roots_file_path, CA_CERT_PATH);
223 
224  grpc_init();
225 
226  for (i = 0; i < sizeof(configs) / sizeof(*configs); i++) {
227  grpc_end2end_tests(argc, argv, configs[i]);
228  }
229 
230  grpc_shutdown();
231 
232  return 0;
233 }
create_proxy_server
static grpc_server * create_proxy_server(const char *port, const grpc_channel_args *server_args)
Definition: h2_ssl_proxy.cc:44
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_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
grpc_end2end_proxy_def
Definition: proxy.h:28
fullstack_secure_fixture_data::proxy
grpc_end2end_proxy * proxy
Definition: h2_ssl_proxy.cc:41
string.h
fail_server_auth_check
static int fail_server_auth_check(const grpc_channel_args *server_args)
Definition: h2_ssl_proxy.cc:166
gpr_free
GPRAPI void gpr_free(void *ptr)
Definition: alloc.cc:51
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
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
gpr_malloc
GPRAPI void * gpr_malloc(size_t size)
Definition: alloc.cc:29
chttp2_tear_down_secure_fullstack
void chttp2_tear_down_secure_fullstack(grpc_end2end_test_fixture *f)
Definition: h2_ssl_proxy.cc:142
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
SERVER_KEY_PATH
#define SERVER_KEY_PATH
Definition: h2_ssl_proxy.cc:38
grpc_end2end_proxy_get_server_port
const char * grpc_end2end_proxy_get_server_port(grpc_end2end_proxy *proxy)
Definition: proxy.cc:466
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
grpc_end2end_proxy_create
grpc_end2end_proxy * grpc_end2end_proxy_create(const grpc_end2end_proxy_def *def, const grpc_channel_args *client_args, const grpc_channel_args *server_args)
Definition: proxy.cc:87
channel
wrapped_grpc_channel * channel
Definition: src/php/ext/grpc/call.h:33
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
chttp2_create_fixture_secure_fullstack
static grpc_end2end_test_fixture chttp2_create_fixture_secure_fullstack(const grpc_channel_args *client_args, const grpc_channel_args *server_args)
Definition: h2_ssl_proxy.cc:89
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
grpc_server_credentials_release
GRPCAPI void grpc_server_credentials_release(grpc_server_credentials *creds)
Definition: credentials.cc:95
FEATURE_MASK_SUPPORTS_REQUEST_PROXYING
#define FEATURE_MASK_SUPPORTS_REQUEST_PROXYING
Definition: end2end_tests.h:36
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
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_proxy.cc:149
fullstack_secure_fixture_data
struct fullstack_secure_fixture_data fullstack_secure_fixture_data
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_server
struct grpc_server grpc_server
Definition: grpc_types.h:65
grpc_server_destroy
GRPCAPI void grpc_server_destroy(grpc_server *server)
Definition: src/core/lib/surface/server.cc:1519
CA_CERT_PATH
#define CA_CERT_PATH
Definition: h2_ssl_proxy.cc:36
end2end_tests.h
ssl_utils_config.h
grpc_core::ExecCtx
Definition: exec_ctx.h:97
GPR_GLOBAL_CONFIG_SET
#define GPR_GLOBAL_CONFIG_SET(name, value)
Definition: global_config_generic.h:26
grpc_end2end_proxy
Definition: proxy.cc:34
tests.unit._exit_scenarios.port
port
Definition: _exit_scenarios.py:179
proxy.h
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
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_proxy.cc:126
create_proxy_client
static grpc_channel * create_proxy_client(const char *target, const grpc_channel_args *client_args)
Definition: h2_ssl_proxy.cc:66
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
main
int main(int argc, char **argv)
Definition: h2_ssl_proxy.cc:217
exec_ctx
grpc_core::ExecCtx exec_ctx
Definition: end2end_binder_transport_test.cc:75
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
proxy_def
static const grpc_end2end_proxy_def proxy_def
Definition: h2_ssl_proxy.cc:86
fullstack_secure_fixture_data
Definition: h2_fakesec.cc:32
state
Definition: bloaty/third_party/zlib/contrib/blast/blast.c:41
configs
static grpc_end2end_test_config configs[]
Definition: h2_ssl_proxy.cc:204
grpc_channel
struct grpc_channel grpc_channel
Definition: grpc_types.h:62
channel_args.h
grpc_end2end_proxy_get_client_target
const char * grpc_end2end_proxy_get_client_target(grpc_end2end_proxy *proxy)
Definition: proxy.cc:462
grpc_end2end_proxy_destroy
void grpc_end2end_proxy_destroy(grpc_end2end_proxy *proxy)
Definition: proxy.cc:139
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_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
SERVER_CERT_PATH
#define SERVER_CERT_PATH
Definition: h2_ssl_proxy.cc:37
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_proxy.cc:106
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_proxy.cc:178
grpc_channel_args::args
grpc_arg * args
Definition: grpc_types.h:134
grpc_shutdown
GRPCAPI void grpc_shutdown(void)
Definition: init.cc:209
setup.target
target
Definition: third_party/bloaty/third_party/protobuf/python/setup.py:179
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
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_proxy.cc:115


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