From e7a106f19d859490b2a41adccb45a75e8ed9731a Mon Sep 17 00:00:00 2001
From: "release-please[bot]"
 <55107282+release-please[bot]@users.noreply.github.com>
Date: Tue, 28 May 2024 16:40:18 +0000
Subject: [PATCH 1/5] chore(main): release 2.6.1-SNAPSHOT (#2489)
:robot: I have created a release *beep* *boop*
---
### Updating meta-information for bleeding-edge SNAPSHOT release.
---
This PR was generated with [Release Please](https://togithub.com/googleapis/release-please). See [documentation](https://togithub.com/googleapis/release-please#release-please).
---
 google-api-client-android/pom.xml   |  2 +-
 google-api-client-appengine/pom.xml |  2 +-
 google-api-client-assembly/pom.xml  |  2 +-
 google-api-client-bom/pom.xml       | 20 ++++++++++----------
 google-api-client-gson/pom.xml      |  2 +-
 google-api-client-jackson2/pom.xml  |  2 +-
 google-api-client-protobuf/pom.xml  |  2 +-
 google-api-client-servlet/pom.xml   |  2 +-
 google-api-client-xml/pom.xml       |  2 +-
 google-api-client/pom.xml           |  2 +-
 pom.xml                             |  2 +-
 versions.txt                        |  2 +-
 12 files changed, 21 insertions(+), 21 deletions(-)
diff --git a/google-api-client-android/pom.xml b/google-api-client-android/pom.xml
index 54ff7b7ad..a51a32360 100644
--- a/google-api-client-android/pom.xml
+++ b/google-api-client-android/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-android
diff --git a/google-api-client-appengine/pom.xml b/google-api-client-appengine/pom.xml
index 613133e62..8c2d326f5 100644
--- a/google-api-client-appengine/pom.xml
+++ b/google-api-client-appengine/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-appengine
diff --git a/google-api-client-assembly/pom.xml b/google-api-client-assembly/pom.xml
index 6c065f16a..0a01e397c 100644
--- a/google-api-client-assembly/pom.xml
+++ b/google-api-client-assembly/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   com.google.api-client
diff --git a/google-api-client-bom/pom.xml b/google-api-client-bom/pom.xml
index 3bf41f17d..0fc725d2e 100644
--- a/google-api-client-bom/pom.xml
+++ b/google-api-client-bom/pom.xml
@@ -3,7 +3,7 @@
   4.0.0
   com.google.api-client
   google-api-client-bom
-  2.6.0
+  2.6.1-SNAPSHOT
   pom
 
   Google API Client Library for Java BOM
@@ -63,48 +63,48 @@
       
         com.google.api-client
         google-api-client
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-android
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-appengine
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-assembly
-        2.6.0
+        2.6.1-SNAPSHOT
         pom
       
       
         com.google.api-client
         google-api-client-gson
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-jackson2
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-protobuf
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-servlet
-        2.6.0
+        2.6.1-SNAPSHOT
       
       
         com.google.api-client
         google-api-client-xml
-        2.6.0
+        2.6.1-SNAPSHOT
       
     
   
diff --git a/google-api-client-gson/pom.xml b/google-api-client-gson/pom.xml
index 65c0c5796..0d250e7c5 100644
--- a/google-api-client-gson/pom.xml
+++ b/google-api-client-gson/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-gson
diff --git a/google-api-client-jackson2/pom.xml b/google-api-client-jackson2/pom.xml
index f1a472cb8..7f6772159 100644
--- a/google-api-client-jackson2/pom.xml
+++ b/google-api-client-jackson2/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-jackson2
diff --git a/google-api-client-protobuf/pom.xml b/google-api-client-protobuf/pom.xml
index 309cf9a21..c6a15cba0 100644
--- a/google-api-client-protobuf/pom.xml
+++ b/google-api-client-protobuf/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-protobuf
diff --git a/google-api-client-servlet/pom.xml b/google-api-client-servlet/pom.xml
index ac488fe00..bf9181a58 100644
--- a/google-api-client-servlet/pom.xml
+++ b/google-api-client-servlet/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-servlet
diff --git a/google-api-client-xml/pom.xml b/google-api-client-xml/pom.xml
index cc8bde53c..7eab46d47 100644
--- a/google-api-client-xml/pom.xml
+++ b/google-api-client-xml/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client-xml
diff --git a/google-api-client/pom.xml b/google-api-client/pom.xml
index 04f156b8c..8d73dbad4 100644
--- a/google-api-client/pom.xml
+++ b/google-api-client/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.0
+    2.6.1-SNAPSHOT
     ../pom.xml
   
   google-api-client
diff --git a/pom.xml b/pom.xml
index eb82f4f52..1d332f0f5 100644
--- a/pom.xml
+++ b/pom.xml
@@ -4,7 +4,7 @@
   4.0.0
   com.google.api-client
   google-api-client-parent
-  2.6.0
+  2.6.1-SNAPSHOT
   pom
   Parent for the Google API Client Library for Java
   The Google APIs Client Library for Java is a Java client library
diff --git a/versions.txt b/versions.txt
index e942840e7..b2a9fc61d 100644
--- a/versions.txt
+++ b/versions.txt
@@ -1,4 +1,4 @@
 # Format:
 # module:released-version:current-version
 
-google-api-client:2.6.0:2.6.0
+google-api-client:2.6.0:2.6.1-SNAPSHOT
From b3df1f6f310a6775161cee193dc5ffed683de5f5 Mon Sep 17 00:00:00 2001
From: Tomo Suzuki 
Date: Tue, 28 May 2024 15:07:15 -0400
Subject: [PATCH 2/5] chore: pinning jakarta servlet API v5 (#2487)
* chore: pinning jakarta servlet API v5
Pinning jakarta servlet API v5 because v6 does not work with Java
8 compilation.
* matchPackageNames
https://docs.renovatebot.com/configuration-options/#matchpackagenames
---
 renovate.json | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/renovate.json b/renovate.json
index a786a0026..f53a16edd 100644
--- a/renovate.json
+++ b/renovate.json
@@ -8,6 +8,11 @@
       "packagePatterns": ["^com.google.appengine:appengine-"],
       "groupName": "AppEngine packages"
     },
+    {
+      "matchPackageNames": ["jakarta.servlet:jakarta.servlet-api"],
+      "groupName": "Jakarta servlet API",
+      "enabled": false,
+    },
     {
       "matchPackagePatterns": [
         "^com.google.guava:"
From 0d39b4383ba0c686abb30148b800f7dfdd273cf2 Mon Sep 17 00:00:00 2001
From: ldetmer <1771267+ldetmer@users.noreply.github.com>
Date: Tue, 27 Aug 2024 11:52:06 -0400
Subject: [PATCH 3/5] feat: Provide HttpTransport support for google
 certificates with apache HTTP client v5 (#2497) (#2503)
provide new GoogleApache5HttpTransport that returns HttpTransport with google certificates using apache HTTP client v5
---
 docs/component-modules.md                     |   9 +
 google-api-client-apache-v5/pom.xml           | 177 ++++++++++++++++++
 .../checkstyle/checkstyle-suppressions.xml    |  10 +
 .../apache/v5/GoogleApache5HttpTransport.java | 148 +++++++++++++++
 .../googleapis/apache/v5/package-info.java    |  20 ++
 .../v5/GoogleApache5HttpTransportTest.java    |  43 +++++
 .../v5/ITGoogleApache5HttpTransportTest.java  |  76 ++++++++
 google-api-client/pom.xml                     |  12 ++
 .../client/googleapis/mtls/MtlsProvider.java  |   3 +-
 .../mtls/MtlsTransportBaseTest.java           |  10 +-
 pom.xml                                       |  20 +-
 11 files changed, 521 insertions(+), 7 deletions(-)
 create mode 100644 google-api-client-apache-v5/pom.xml
 create mode 100644 google-api-client-apache-v5/src/checkstyle/checkstyle-suppressions.xml
 create mode 100644 google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransport.java
 create mode 100644 google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/package-info.java
 create mode 100644 google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransportTest.java
 create mode 100644 google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/ITGoogleApache5HttpTransportTest.java
diff --git a/docs/component-modules.md b/docs/component-modules.md
index 7277febc0..ad780053b 100644
--- a/docs/component-modules.md
+++ b/docs/component-modules.md
@@ -55,4 +55,13 @@ XML extensions to the Google API Client Library for Java
 (`google-api-client-xml`). This module depends on `google-api-client` and
 `google-http-client-xml`.
 
+## google-api-client-apache-v5
+
+Provides Apache extension to the Google HTTP Client Library for Java (`google-api-client-apache-v5`) that
+returns an implementation of `HttpTransport` based on the Apache HTTP Client (v5) with Google certificates loaded in
+truststore. This module depends on `google-http-client`.
+
+Please note this is the preferred Apache extension to be used, over the GoogleApacheHttpTransport included
+in `google-api-client` module. The previous google transport utilizes the EOL Apache HTTP Client v4.
+
 [protobuf]: https://developers.google.com/protocol-buffers/docs/overview
diff --git a/google-api-client-apache-v5/pom.xml b/google-api-client-apache-v5/pom.xml
new file mode 100644
index 000000000..8c5350d79
--- /dev/null
+++ b/google-api-client-apache-v5/pom.xml
@@ -0,0 +1,177 @@
+
+
+    4.0.0
+    
+        com.google.api-client
+        google-api-client-parent
+        2.6.1-SNAPSHOT
+    
+    google-api-client-apache-v5
+    Apache extensions to the Google APIs Client Library for Java
+    
+        
+            
+                org.apache.maven.plugins
+                maven-resources-plugin
+                
+                    
+                        
+                            resources
+                        
+                    
+                
+            
+            
+                maven-javadoc-plugin
+                
+                    
+                        https://docs.oracle.com/javase/8/docs/api/
+                        https://cloud.google.com/appengine/docs/standard/java/javadoc/
+                        https://googleapis.dev/java/google-http-client/${project.http.version}/
+                        https://googleapis.dev/java/google-oauth-client/${project.oauth.version}/
+                    
+                    ${project.name} ${project.version}
+                    ${project.artifactId} ${project.version}
+                
+            
+            
+                maven-jar-plugin
+                
+                    
+                        ${project.build.outputDirectory}/META-INF/MANIFEST.MF
+                        
+                            true
+                        
+                        
+                            google.api.client
+                        
+                        ${project.build.outputDirectory}/META-INF/MANIFEST.MF
+                    
+                
+            
+            
+                org.apache.felix
+                maven-bundle-plugin
+                5.1.9
+                
+                    
+                        bundle-manifest
+                        process-classes
+                        
+                            manifest
+                        
+                    
+                
+                
+                    
+                        https://developers.google.com/api-client-library/java/
+                        Google HTTP transport wrapper for the Apache 5 Http Client.
+                        
+                        com.google.api.client.googleapis.apache
+                    
+                
+            
+            
+                maven-source-plugin
+                
+                    
+                        source-jar
+                        
+                            jar
+                        
+                    
+                
+            
+            
+                org.apache.maven.plugins
+                maven-checkstyle-plugin
+                
+                    
+                        validate-google-style
+                        validate
+                        
+                            check
+                        
+                        
+                            google_checks.xml
+                            src/checkstyle/checkstyle-suppressions.xml
+                            true
+                            true
+                            warning
+                        
+                    
+                
+            
+        
+
+        
+            
+                src/main/resources
+            
+            
+                src/main/properties
+                true
+            
+        
+    
+    
+        
+            junit
+            junit
+            test
+        
+        
+            com.google.api-client
+            google-api-client
+            
+                
+                    org.apache.httpcomponents
+                    httpcore
+                
+                
+                    org.apache.httpcomponents
+                    httpclient
+                
+            
+        
+        
+            com.google.http-client
+            google-http-client-apache-v5
+        
+        
+            com.google.guava
+            guava
+        
+        
+            org.apache.httpcomponents.client5
+            httpclient5
+        
+        
+            org.apache.httpcomponents.core5
+            httpcore5
+        
+        
+            com.google.http-client
+            google-http-client
+            
+                
+                    org.apache.httpcomponents
+                    httpcore
+                
+                
+                    org.apache.httpcomponents
+                    httpclient
+                
+            
+        
+        
+            com.google.api-client
+            google-api-client
+            test-jar
+            test
+             ${project.version}
+        
+    
+
diff --git a/google-api-client-apache-v5/src/checkstyle/checkstyle-suppressions.xml b/google-api-client-apache-v5/src/checkstyle/checkstyle-suppressions.xml
new file mode 100644
index 000000000..812319b66
--- /dev/null
+++ b/google-api-client-apache-v5/src/checkstyle/checkstyle-suppressions.xml
@@ -0,0 +1,10 @@
+
+
+
+    
+    
+    
+    
+
diff --git a/google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransport.java b/google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransport.java
new file mode 100644
index 000000000..00a7673b3
--- /dev/null
+++ b/google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransport.java
@@ -0,0 +1,148 @@
+/*
+ * Copyright 2024 Google LLC
+ *
+ * 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.
+ */
+
+package com.google.api.client.googleapis.apache.v5;
+
+import com.google.api.client.googleapis.GoogleUtils;
+import com.google.api.client.googleapis.mtls.MtlsProvider;
+import com.google.api.client.googleapis.mtls.MtlsUtils;
+import com.google.api.client.googleapis.util.Utils;
+import com.google.api.client.http.apache.v5.Apache5HttpTransport;
+import com.google.api.client.util.SslUtils;
+import com.google.common.annotations.Beta;
+import com.google.common.annotations.VisibleForTesting;
+import java.io.IOException;
+import java.net.ProxySelector;
+import java.security.GeneralSecurityException;
+import java.security.KeyStore;
+import java.util.concurrent.TimeUnit;
+import javax.net.ssl.SSLContext;
+import org.apache.hc.client5.http.config.ConnectionConfig;
+import org.apache.hc.client5.http.impl.classic.CloseableHttpClient;
+import org.apache.hc.client5.http.impl.classic.HttpClients;
+import org.apache.hc.client5.http.impl.io.PoolingHttpClientConnectionManager;
+import org.apache.hc.client5.http.impl.routing.SystemDefaultRoutePlanner;
+import org.apache.hc.client5.http.socket.ConnectionSocketFactory;
+import org.apache.hc.client5.http.socket.LayeredConnectionSocketFactory;
+import org.apache.hc.client5.http.socket.PlainConnectionSocketFactory;
+import org.apache.hc.client5.http.ssl.SSLConnectionSocketFactory;
+import org.apache.hc.core5.http.config.Registry;
+import org.apache.hc.core5.http.config.RegistryBuilder;
+
+/**
+ * Utilities for Google APIs based on {@link Apache5HttpTransport}.
+ *
+ * @since 2.6.1
+ */
+public final class GoogleApache5HttpTransport {
+
+  /**
+   * Returns a new instance of {@link Apache5HttpTransport} that uses {@link
+   * GoogleUtils#getCertificateTrustStore()} for the trusted certificates. If
+   * `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is set to "true", and the default
+   * client certificate key store from {@link Utils#loadDefaultMtlsKeyStore()} is not null, then the
+   * transport uses the default client certificate and is mutual TLS.
+   */
+  public static Apache5HttpTransport newTrustedTransport()
+      throws GeneralSecurityException, IOException {
+    return newTrustedTransport(MtlsUtils.getDefaultMtlsProvider());
+  }
+
+  /**
+   * {@link Beta} 
+   * Returns a new instance of {@link Apache5HttpTransport} that uses {@link
+   * GoogleUtils#getCertificateTrustStore()} for the trusted certificates. mtlsProvider can be used
+   * to configure mutual TLS for the transport.
+   *
+   * @param mtlsProvider MtlsProvider to configure mutual TLS for the transport
+   */
+  @Beta
+  public static Apache5HttpTransport newTrustedTransport(MtlsProvider mtlsProvider)
+      throws GeneralSecurityException, IOException {
+
+    SocketFactoryRegistryHandler handler = new SocketFactoryRegistryHandler(mtlsProvider);
+
+    PoolingHttpClientConnectionManager connectionManager =
+        new PoolingHttpClientConnectionManager(handler.getSocketFactoryRegistry());
+    connectionManager.setMaxTotal(200);
+    connectionManager.setDefaultMaxPerRoute(20);
+    connectionManager.setDefaultConnectionConfig(
+        ConnectionConfig.custom()
+            .setTimeToLive(-1, TimeUnit.MILLISECONDS)
+            .setValidateAfterInactivity(-1L, TimeUnit.MILLISECONDS)
+            .build());
+
+    CloseableHttpClient client =
+        HttpClients.custom()
+            .useSystemProperties()
+            .setConnectionManager(connectionManager)
+            .setRoutePlanner(new SystemDefaultRoutePlanner(ProxySelector.getDefault()))
+            .disableRedirectHandling()
+            .disableAutomaticRetries()
+            .build();
+
+    return new Apache5HttpTransport(client, handler.isMtls());
+  }
+
+  @VisibleForTesting
+  static class SocketFactoryRegistryHandler {
+    private final Registry socketFactoryRegistry;
+    private final boolean isMtls;
+
+    public SocketFactoryRegistryHandler(MtlsProvider mtlsProvider)
+        throws GeneralSecurityException, IOException {
+      KeyStore mtlsKeyStore = null;
+      String mtlsKeyStorePassword = null;
+      if (mtlsProvider.useMtlsClientCertificate()) {
+        mtlsKeyStore = mtlsProvider.getKeyStore();
+        mtlsKeyStorePassword = mtlsProvider.getKeyStorePassword();
+      }
+
+      // Use the included trust store
+      KeyStore trustStore = GoogleUtils.getCertificateTrustStore();
+      SSLContext sslContext = SslUtils.getTlsSslContext();
+
+      if (mtlsKeyStore != null && mtlsKeyStorePassword != null) {
+        this.isMtls = true;
+        SslUtils.initSslContext(
+            sslContext,
+            trustStore,
+            SslUtils.getPkixTrustManagerFactory(),
+            mtlsKeyStore,
+            mtlsKeyStorePassword,
+            SslUtils.getDefaultKeyManagerFactory());
+      } else {
+        this.isMtls = false;
+        SslUtils.initSslContext(sslContext, trustStore, SslUtils.getPkixTrustManagerFactory());
+      }
+      LayeredConnectionSocketFactory socketFactory = new SSLConnectionSocketFactory(sslContext);
+
+      this.socketFactoryRegistry =
+          RegistryBuilder.create()
+              .register("http", PlainConnectionSocketFactory.getSocketFactory())
+              .register("https", socketFactory)
+              .build();
+    }
+
+    public Registry getSocketFactoryRegistry() {
+      return this.socketFactoryRegistry;
+    }
+
+    public boolean isMtls() {
+      return this.isMtls;
+    }
+  }
+
+  private GoogleApache5HttpTransport() {}
+}
diff --git a/google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/package-info.java b/google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/package-info.java
new file mode 100644
index 000000000..f4a1e9131
--- /dev/null
+++ b/google-api-client-apache-v5/src/main/java/com/google/api/client/googleapis/apache/v5/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2024 Google LLC
+ *
+ * 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.
+ */
+
+/**
+ * Google APIs support based on the Apache HTTP Client v5.
+ *
+ * @since 2.6.1
+ */
+package com.google.api.client.googleapis.apache.v5;
diff --git a/google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransportTest.java b/google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransportTest.java
new file mode 100644
index 000000000..07728325a
--- /dev/null
+++ b/google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/GoogleApache5HttpTransportTest.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2024 Google LLC
+ *
+ * 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.
+ */
+
+package com.google.api.client.googleapis.apache.v5;
+
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertTrue;
+
+import com.google.api.client.googleapis.mtls.MtlsProvider;
+import com.google.api.client.googleapis.mtls.MtlsTransportBaseTest;
+import com.google.api.client.http.HttpTransport;
+import java.io.IOException;
+import java.security.GeneralSecurityException;
+import org.junit.Test;
+
+public class GoogleApache5HttpTransportTest extends MtlsTransportBaseTest {
+  @Override
+  protected HttpTransport buildTrustedTransport(MtlsProvider mtlsProvider)
+      throws GeneralSecurityException, IOException {
+    return GoogleApache5HttpTransport.newTrustedTransport(mtlsProvider);
+  }
+
+  @Test
+  public void socketFactoryRegistryHandlerTest() throws GeneralSecurityException, IOException {
+    MtlsProvider mtlsProvider = new TestMtlsProvider(true, createTestMtlsKeyStore(), "", false);
+    GoogleApache5HttpTransport.SocketFactoryRegistryHandler handler =
+        new GoogleApache5HttpTransport.SocketFactoryRegistryHandler(mtlsProvider);
+    assertNotNull(handler.getSocketFactoryRegistry().lookup("http"));
+    assertNotNull(handler.getSocketFactoryRegistry().lookup("https"));
+    assertTrue(handler.isMtls());
+  }
+}
diff --git a/google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/ITGoogleApache5HttpTransportTest.java b/google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/ITGoogleApache5HttpTransportTest.java
new file mode 100644
index 000000000..f8e9cbed1
--- /dev/null
+++ b/google-api-client-apache-v5/src/test/java/com/google/api/client/googleapis/apache/v5/ITGoogleApache5HttpTransportTest.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2024 Google LLC
+ *
+ * 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.
+ */
+
+package com.google.api.client.googleapis.apache.v5;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.fail;
+
+import com.google.api.client.http.apache.v5.Apache5HttpTransport;
+import java.io.IOException;
+import java.security.GeneralSecurityException;
+import javax.net.ssl.SSLHandshakeException;
+import org.apache.hc.client5.http.classic.methods.HttpGet;
+import org.apache.hc.core5.http.ClassicHttpResponse;
+import org.apache.hc.core5.http.io.HttpClientResponseHandler;
+import org.junit.Test;
+
+public class ITGoogleApache5HttpTransportTest {
+
+  @Test
+  public void testHttpRequestFailsWhenMakingRequestToSiteWithoutGoogleCerts()
+      throws GeneralSecurityException, IOException {
+    Apache5HttpTransport apache5HttpTransport = GoogleApache5HttpTransport.newTrustedTransport();
+    HttpGet httpGet = new HttpGet("https://maven.com/");
+    Exception exception = null;
+    try {
+      apache5HttpTransport
+          .getHttpClient()
+          .execute(
+              httpGet,
+              new HttpClientResponseHandler() {
+                @Override
+                public Void handleResponse(ClassicHttpResponse response) {
+                  fail("Should not have been able to complete SSL request on non google site.");
+                  return null;
+                }
+              });
+      fail("Expected SSLHandshakeException was not thrown");
+    } catch (SSLHandshakeException e) {
+      exception = e;
+    }
+
+    assertNotNull(exception);
+    assertEquals(exception.getClass(), SSLHandshakeException.class);
+  }
+
+  @Test
+  public void testHttpRequestPassesWhenMakingRequestToGoogleSite() throws Exception {
+    Apache5HttpTransport apache5HttpTransport = GoogleApache5HttpTransport.newTrustedTransport();
+    HttpGet httpGet = new HttpGet("https://www.google.com/");
+
+    apache5HttpTransport
+        .getHttpClient()
+        .execute(
+            httpGet,
+            new HttpClientResponseHandler() {
+              @Override
+              public Void handleResponse(ClassicHttpResponse response) {
+                assertEquals(200, response.getCode());
+                return null;
+              }
+            });
+  }
+}
diff --git a/google-api-client/pom.xml b/google-api-client/pom.xml
index 8d73dbad4..d42452c6d 100644
--- a/google-api-client/pom.xml
+++ b/google-api-client/pom.xml
@@ -87,6 +87,18 @@
               jar
             
           
+          
+            Jar Tests Package
+            package
+            
+              test-jar
+            
+            
+              
+                **/Mtls/**
+              
+            
+          
         
       
       
diff --git a/google-api-client/src/main/java/com/google/api/client/googleapis/mtls/MtlsProvider.java b/google-api-client/src/main/java/com/google/api/client/googleapis/mtls/MtlsProvider.java
index cb0813b45..abec44b7a 100644
--- a/google-api-client/src/main/java/com/google/api/client/googleapis/mtls/MtlsProvider.java
+++ b/google-api-client/src/main/java/com/google/api/client/googleapis/mtls/MtlsProvider.java
@@ -22,7 +22,8 @@
 /**
  * {@link Beta} 
  * Provider interface for mutual TLS. It is used in {@link
- * GoogleApacheHttpTransport#newTrustedTransport(MtlsProvider)} and {@link
+ * GoogleApacheHttpTransport#newTrustedTransport(MtlsProvider)}, {@link
+ * GoogleApache5HttpTransport#newTrustedTransport(MtlsProvider)} and {@link
  * GoogleNetHttpTransport#newTrustedTransport(MtlsProvider)} to configure the mutual TLS in the
  * transport.
  *
diff --git a/google-api-client/src/test/java/com/google/api/client/googleapis/mtls/MtlsTransportBaseTest.java b/google-api-client/src/test/java/com/google/api/client/googleapis/mtls/MtlsTransportBaseTest.java
index 096ff4abf..87b44fdf4 100644
--- a/google-api-client/src/test/java/com/google/api/client/googleapis/mtls/MtlsTransportBaseTest.java
+++ b/google-api-client/src/test/java/com/google/api/client/googleapis/mtls/MtlsTransportBaseTest.java
@@ -35,11 +35,11 @@ protected KeyStore createTestMtlsKeyStore() throws IOException, GeneralSecurityE
     return SecurityUtils.createMtlsKeyStore(certAndKey);
   }
 
-  protected static class TestMtlsProvider implements MtlsProvider {
-    private boolean useClientCertificate;
-    private KeyStore keyStore;
-    private String keyStorePassword;
-    private boolean throwExceptionForGetKeyStore;
+  public static class TestMtlsProvider implements MtlsProvider {
+    private final boolean useClientCertificate;
+    private final KeyStore keyStore;
+    private final String keyStorePassword;
+    private final boolean throwExceptionForGetKeyStore;
 
     public TestMtlsProvider(
         boolean useClientCertificate,
diff --git a/pom.xml b/pom.xml
index 1d332f0f5..5fa6a62d4 100644
--- a/pom.xml
+++ b/pom.xml
@@ -80,6 +80,7 @@
     google-api-client-jackson2
     google-api-client-protobuf
     google-api-client-xml
+    google-api-client-apache-v5
   
 
   
@@ -241,6 +242,21 @@
         ${gson.version}
         test
       
+      
+        org.apache.httpcomponents.client5
+        httpclient5
+        ${project.httpclient5.version}
+      
+      
+        org.apache.httpcomponents.core5
+        httpcore5
+        ${project.httpcore5.version}
+      
+      
+        com.google.http-client
+        google-http-client-apache-v5
+        ${project.http.version}
+      
     
   
 
@@ -513,9 +529,11 @@
   
   
     UTF-8
-    1.44.2
+    1.45.0
     4.4.16
     4.5.14
+    5.2.4
+    5.3.1
     1.17.0
     1.36.0
     1.23.0
From b8fa311bce05acb42c418548d80d5c8d0cf7cf77 Mon Sep 17 00:00:00 2001
From: ldetmer <1771267+ldetmer@users.noreply.github.com>
Date: Tue, 27 Aug 2024 14:22:42 -0400
Subject: [PATCH 4/5] feat: fixed missing version placeholder for new pom file
 (#2506)
---
 google-api-client-apache-v5/pom.xml | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/google-api-client-apache-v5/pom.xml b/google-api-client-apache-v5/pom.xml
index 8c5350d79..b4e25f03d 100644
--- a/google-api-client-apache-v5/pom.xml
+++ b/google-api-client-apache-v5/pom.xml
@@ -6,7 +6,7 @@
     
         com.google.api-client
         google-api-client-parent
-        2.6.1-SNAPSHOT
+        2.6.1-SNAPSHOT
     
     google-api-client-apache-v5
     Apache extensions to the Google APIs Client Library for Java
From 6c3b57c465018c7213e6e0dbec60977c4b099957 Mon Sep 17 00:00:00 2001
From: "release-please[bot]"
 <55107282+release-please[bot]@users.noreply.github.com>
Date: Tue, 27 Aug 2024 16:26:29 -0400
Subject: [PATCH 5/5] chore(main): release 2.7.0 (#2504)
Co-authored-by: release-please[bot] <55107282+release-please[bot]@users.noreply.github.com>
---
 CHANGELOG.md                        |  8 ++++++++
 google-api-client-android/pom.xml   |  2 +-
 google-api-client-apache-v5/pom.xml |  2 +-
 google-api-client-appengine/pom.xml |  2 +-
 google-api-client-assembly/pom.xml  |  2 +-
 google-api-client-bom/pom.xml       | 20 ++++++++++----------
 google-api-client-gson/pom.xml      |  2 +-
 google-api-client-jackson2/pom.xml  |  2 +-
 google-api-client-protobuf/pom.xml  |  2 +-
 google-api-client-servlet/pom.xml   |  2 +-
 google-api-client-xml/pom.xml       |  2 +-
 google-api-client/pom.xml           |  2 +-
 pom.xml                             |  2 +-
 versions.txt                        |  2 +-
 14 files changed, 30 insertions(+), 22 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 74d1520d8..27ff31358 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,5 +1,13 @@
 # Changelog
 
+## [2.7.0](https://github.com/googleapis/google-api-java-client/compare/v2.6.0...v2.7.0) (2024-08-27)
+
+
+### Features
+
+* Fixed missing version placeholder for new pom file ([#2506](https://github.com/googleapis/google-api-java-client/issues/2506)) ([b8fa311](https://github.com/googleapis/google-api-java-client/commit/b8fa311bce05acb42c418548d80d5c8d0cf7cf77))
+* Provide HttpTransport support for google certificates with apache HTTP client v5 ([#2497](https://github.com/googleapis/google-api-java-client/issues/2497)) ([#2503](https://github.com/googleapis/google-api-java-client/issues/2503)) ([0d39b43](https://github.com/googleapis/google-api-java-client/commit/0d39b4383ba0c686abb30148b800f7dfdd273cf2))
+
 ## [2.6.0](https://github.com/googleapis/google-api-java-client/compare/v2.5.1...v2.6.0) (2024-05-24)
 
 
diff --git a/google-api-client-android/pom.xml b/google-api-client-android/pom.xml
index a51a32360..9bc42e6b8 100644
--- a/google-api-client-android/pom.xml
+++ b/google-api-client-android/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-android
diff --git a/google-api-client-apache-v5/pom.xml b/google-api-client-apache-v5/pom.xml
index b4e25f03d..e1ce936df 100644
--- a/google-api-client-apache-v5/pom.xml
+++ b/google-api-client-apache-v5/pom.xml
@@ -6,7 +6,7 @@
     
         com.google.api-client
         google-api-client-parent
-        2.6.1-SNAPSHOT
+        2.7.0
     
     google-api-client-apache-v5
     Apache extensions to the Google APIs Client Library for Java
diff --git a/google-api-client-appengine/pom.xml b/google-api-client-appengine/pom.xml
index 8c2d326f5..4c26e11f1 100644
--- a/google-api-client-appengine/pom.xml
+++ b/google-api-client-appengine/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-appengine
diff --git a/google-api-client-assembly/pom.xml b/google-api-client-assembly/pom.xml
index 0a01e397c..5962a189f 100644
--- a/google-api-client-assembly/pom.xml
+++ b/google-api-client-assembly/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   com.google.api-client
diff --git a/google-api-client-bom/pom.xml b/google-api-client-bom/pom.xml
index 0fc725d2e..dc072a117 100644
--- a/google-api-client-bom/pom.xml
+++ b/google-api-client-bom/pom.xml
@@ -3,7 +3,7 @@
   4.0.0
   com.google.api-client
   google-api-client-bom
-  2.6.1-SNAPSHOT
+  2.7.0
   pom
 
   Google API Client Library for Java BOM
@@ -63,48 +63,48 @@
       
         com.google.api-client
         google-api-client
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-android
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-appengine
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-assembly
-        2.6.1-SNAPSHOT
+        2.7.0
         pom
       
       
         com.google.api-client
         google-api-client-gson
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-jackson2
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-protobuf
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-servlet
-        2.6.1-SNAPSHOT
+        2.7.0
       
       
         com.google.api-client
         google-api-client-xml
-        2.6.1-SNAPSHOT
+        2.7.0
       
     
   
diff --git a/google-api-client-gson/pom.xml b/google-api-client-gson/pom.xml
index 0d250e7c5..73d56c496 100644
--- a/google-api-client-gson/pom.xml
+++ b/google-api-client-gson/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-gson
diff --git a/google-api-client-jackson2/pom.xml b/google-api-client-jackson2/pom.xml
index 7f6772159..12325a7a4 100644
--- a/google-api-client-jackson2/pom.xml
+++ b/google-api-client-jackson2/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-jackson2
diff --git a/google-api-client-protobuf/pom.xml b/google-api-client-protobuf/pom.xml
index c6a15cba0..24e0a95e1 100644
--- a/google-api-client-protobuf/pom.xml
+++ b/google-api-client-protobuf/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-protobuf
diff --git a/google-api-client-servlet/pom.xml b/google-api-client-servlet/pom.xml
index bf9181a58..9245f0f20 100644
--- a/google-api-client-servlet/pom.xml
+++ b/google-api-client-servlet/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-servlet
diff --git a/google-api-client-xml/pom.xml b/google-api-client-xml/pom.xml
index 7eab46d47..5486e0f4c 100644
--- a/google-api-client-xml/pom.xml
+++ b/google-api-client-xml/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client-xml
diff --git a/google-api-client/pom.xml b/google-api-client/pom.xml
index d42452c6d..c733ab0a7 100644
--- a/google-api-client/pom.xml
+++ b/google-api-client/pom.xml
@@ -4,7 +4,7 @@
   
     com.google.api-client
     google-api-client-parent
-    2.6.1-SNAPSHOT
+    2.7.0
     ../pom.xml
   
   google-api-client
diff --git a/pom.xml b/pom.xml
index 5fa6a62d4..c0d2a9e24 100644
--- a/pom.xml
+++ b/pom.xml
@@ -4,7 +4,7 @@
   4.0.0
   com.google.api-client
   google-api-client-parent
-  2.6.1-SNAPSHOT
+  2.7.0
   pom
   Parent for the Google API Client Library for Java
   The Google APIs Client Library for Java is a Java client library
diff --git a/versions.txt b/versions.txt
index b2a9fc61d..9b5fdc617 100644
--- a/versions.txt
+++ b/versions.txt
@@ -1,4 +1,4 @@
 # Format:
 # module:released-version:current-version
 
-google-api-client:2.6.0:2.6.1-SNAPSHOT
+google-api-client:2.7.0:2.7.0