/* * * Copyright 2015 gRPC authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #include "test/cpp/interop/client_helper.h" #include #include #include #include #include #include #include #include #include #include "absl/flags/flag.h" #include "src/cpp/client/secure_credentials.h" #include "test/core/security/oauth2_utils.h" #include "test/cpp/util/create_test_channel.h" #include "test/cpp/util/test_credentials_provider.h" ABSL_DECLARE_FLAG(bool, use_alts); ABSL_DECLARE_FLAG(bool, use_tls); ABSL_DECLARE_FLAG(std::string, custom_credentials_type); ABSL_DECLARE_FLAG(bool, use_test_ca); ABSL_DECLARE_FLAG(int32_t, server_port); ABSL_DECLARE_FLAG(std::string, server_host); ABSL_DECLARE_FLAG(std::string, server_host_override); ABSL_DECLARE_FLAG(std::string, test_case); ABSL_DECLARE_FLAG(std::string, default_service_account); ABSL_DECLARE_FLAG(std::string, service_account_key_file); ABSL_DECLARE_FLAG(std::string, oauth_scope); namespace grpc { namespace testing { std::string GetServiceAccountJsonKey() { static std::string json_key; if (json_key.empty()) { std::ifstream json_key_file(absl::GetFlag(FLAGS_service_account_key_file)); std::stringstream key_stream; key_stream << json_key_file.rdbuf(); json_key = key_stream.str(); } return json_key; } std::string GetOauth2AccessToken() { std::shared_ptr creds = GoogleComputeEngineCredentials(); SecureCallCredentials* secure_creds = dynamic_cast(creds.get()); GPR_ASSERT(secure_creds != nullptr); grpc_call_credentials* c_creds = secure_creds->GetRawCreds(); char* token = grpc_test_fetch_oauth2_token_with_credentials(c_creds); GPR_ASSERT(token != nullptr); gpr_log(GPR_INFO, "Get raw oauth2 access token: %s", token); std::string access_token(token + sizeof("Bearer ") - 1); gpr_free(token); return access_token; } void UpdateActions( std::unordered_map>* /*actions*/) {} std::shared_ptr CreateChannelForTestCase( const std::string& test_case, std::vector< std::unique_ptr> interceptor_creators) { GPR_ASSERT(absl::GetFlag(FLAGS_server_port)); const int host_port_buf_size = 1024; char host_port[host_port_buf_size]; snprintf(host_port, host_port_buf_size, "%s:%d", absl::GetFlag(FLAGS_server_host).c_str(), absl::GetFlag(FLAGS_server_port)); std::shared_ptr creds; if (test_case == "compute_engine_creds") { creds = absl::GetFlag(FLAGS_custom_credentials_type) == "google_default_credentials" ? nullptr : GoogleComputeEngineCredentials(); } else if (test_case == "jwt_token_creds") { std::string json_key = GetServiceAccountJsonKey(); std::chrono::seconds token_lifetime = std::chrono::hours(1); creds = absl::GetFlag(FLAGS_custom_credentials_type) == "google_default_credentials" ? nullptr : ServiceAccountJWTAccessCredentials(json_key, token_lifetime.count()); } else if (test_case == "oauth2_auth_token") { creds = absl::GetFlag(FLAGS_custom_credentials_type) == "google_default_credentials" ? nullptr : AccessTokenCredentials(GetOauth2AccessToken()); } else if (test_case == "pick_first_unary") { ChannelArguments channel_args; // allow the LB policy to be configured with service config channel_args.SetInt(GRPC_ARG_SERVICE_CONFIG_DISABLE_RESOLUTION, 0); return CreateTestChannel( host_port, absl::GetFlag(FLAGS_custom_credentials_type), absl::GetFlag(FLAGS_server_host_override), !absl::GetFlag(FLAGS_use_test_ca), creds, channel_args); } if (absl::GetFlag(FLAGS_custom_credentials_type).empty()) { transport_security security_type = absl::GetFlag(FLAGS_use_alts) ? ALTS : (absl::GetFlag(FLAGS_use_tls) ? TLS : INSECURE); return CreateTestChannel(host_port, absl::GetFlag(FLAGS_server_host_override), security_type, !absl::GetFlag(FLAGS_use_test_ca), creds, std::move(interceptor_creators)); } else { if (interceptor_creators.empty()) { return CreateTestChannel( host_port, absl::GetFlag(FLAGS_custom_credentials_type), creds); } else { return CreateTestChannel(host_port, absl::GetFlag(FLAGS_custom_credentials_type), creds, std::move(interceptor_creators)); } } } } // namespace testing } // namespace grpc