Skip to content

Commit

Permalink
Fix HttpClientGitHubConnector to use redirects
Browse files Browse the repository at this point in the history
Fixes #1305
  • Loading branch information
bitwiseman committed Nov 21, 2021
1 parent 65d6de2 commit 988f603
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 19 deletions.
17 changes: 15 additions & 2 deletions src/main/java/org/kohsuke/github/GitHubClient.java
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,7 @@

import static com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility.ANY;
import static com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility.NONE;
import static java.net.HttpURLConnection.HTTP_BAD_REQUEST;
import static java.net.HttpURLConnection.HTTP_UNAUTHORIZED;
import static java.net.HttpURLConnection.*;
import static java.util.logging.Level.*;
import static org.apache.commons.lang3.StringUtils.defaultString;

Expand Down Expand Up @@ -413,6 +412,7 @@ private void detectKnownErrors(GitHubConnectorResponse connectorResponse,
boolean detectStatusCodeError) throws IOException {
detectOTPRequired(connectorResponse);
detectInvalidCached404Response(connectorResponse, request);
detectRedirect(connectorResponse);
if (rateLimitHandler.isError(connectorResponse)) {
rateLimitHandler.onError(connectorResponse);
throw new RetryRequestException();
Expand All @@ -425,6 +425,19 @@ private void detectKnownErrors(GitHubConnectorResponse connectorResponse,
}
}

private void detectRedirect(GitHubConnectorResponse connectorResponse) throws IOException {
if (connectorResponse.statusCode() == HTTP_MOVED_PERM || connectorResponse.statusCode() == HTTP_MOVED_TEMP) {
// GitHubClient depends on GitHubConnector implementations to follow any redirects automatically
// If this is not done and a redirect is requested, throw in order to maintain security and consistency
throw new HttpException(
"GitHubConnnector did not automatically follow redirect.\n"
+ "Change your http client configuration to automatically follow redirects as appropriate.",
connectorResponse.statusCode(),
"Redirect",
connectorResponse.request().url().toString());
}
}

private GitHubConnectorRequest prepareConnectorRequest(GitHubRequest request) throws IOException {
GitHubRequest.Builder<?> builder = request.toBuilder();
// if the authentication is needed but no credential is given, try it anyway (so that some calls
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,10 +28,10 @@ public class HttpClientGitHubConnector implements GitHubConnector {
private final HttpClient client;

/**
* Instantiates a new HttpClientGitHubConnector with a defaut HttpClient.
* Instantiates a new HttpClientGitHubConnector with a default HttpClient.
*/
public HttpClientGitHubConnector() {
this(HttpClient.newHttpClient());
this(HttpClient.newBuilder().followRedirects(HttpClient.Redirect.NORMAL).build());
}

/**
Expand Down
15 changes: 0 additions & 15 deletions src/test/java/org/kohsuke/github/GHWorkflowRunTest.java
Original file line number Diff line number Diff line change
@@ -1,15 +1,12 @@
package org.kohsuke.github;

import org.awaitility.Awaitility;
import org.junit.Assume;
import org.junit.Before;
import org.junit.Test;
import org.kohsuke.github.GHWorkflowJob.Step;
import org.kohsuke.github.GHWorkflowRun.Conclusion;
import org.kohsuke.github.GHWorkflowRun.Status;
import org.kohsuke.github.extras.HttpClientGitHubConnector;
import org.kohsuke.github.function.InputStreamFunction;
import org.kohsuke.github.internal.DefaultGitHubConnector;

import java.io.IOException;
import java.time.Duration;
Expand Down Expand Up @@ -201,10 +198,6 @@ public void testSearchOnBranch() throws IOException {

@Test
public void testLogs() throws IOException {
// This test fails for HttpClientGitHubConnector.
// Not sure why, but it is better to move forward and come back to it later
Assume.assumeFalse(DefaultGitHubConnector.create() instanceof HttpClientGitHubConnector);

GHWorkflow workflow = repo.getWorkflow(FAST_WORKFLOW_PATH);

long latestPreexistingWorkflowRunId = getLatestPreexistingWorkflowRunId();
Expand Down Expand Up @@ -243,10 +236,6 @@ public void testLogs() throws IOException {
@SuppressWarnings("resource")
@Test
public void testArtifacts() throws IOException {
// This test fails for HttpClientGitHubConnector.
// Not sure why, but it is better to move forward and come back to it later
Assume.assumeFalse(DefaultGitHubConnector.create() instanceof HttpClientGitHubConnector);

GHWorkflow workflow = repo.getWorkflow(ARTIFACTS_WORKFLOW_PATH);

long latestPreexistingWorkflowRunId = getLatestPreexistingWorkflowRunId();
Expand Down Expand Up @@ -327,10 +316,6 @@ public void testArtifacts() throws IOException {

@Test
public void testJobs() throws IOException {
// This test fails for HttpClientGitHubConnector.
// Not sure why, but it is better to move forward and come back to it later
Assume.assumeFalse(DefaultGitHubConnector.create() instanceof HttpClientGitHubConnector);

GHWorkflow workflow = repo.getWorkflow(MULTI_JOBS_WORKFLOW_PATH);

long latestPreexistingWorkflowRunId = getLatestPreexistingWorkflowRunId();
Expand Down

0 comments on commit 988f603

Please sign in to comment.