in src/main/java/com/googlesource/gerrit/plugins/replication/pull/ReplicationQueue.java [306:336]
private void callFetch(
Source source, Project.NameKey project, String refName, ReplicationState state) {
if (source.wouldFetchProject(project) && source.wouldFetchRef(refName)) {
for (String apiUrl : source.getApis()) {
try {
URIish uri = new URIish(apiUrl);
FetchRestApiClient fetchClient = fetchClientFactory.create(source);
HttpResult result = fetchClient.callFetch(project, refName, uri);
if (isProjectMissing(result, project) && source.isCreateMissingRepositories()) {
result = initProject(project, uri, fetchClient, result);
}
if (!result.isSuccessful()) {
stateLog.warn(
String.format(
"Pull replication rest api fetch call failed. Endpoint url: %s, reason:%s",
apiUrl, result.getMessage().orElse("unknown")),
state);
}
} catch (URISyntaxException e) {
stateLog.error(String.format("Cannot parse pull replication api url:%s", apiUrl), state);
} catch (Exception e) {
stateLog.error(
String.format(
"Exception during the pull replication fetch rest api call. Endpoint url:%s, message:%s",
apiUrl, e.getMessage()),
e,
state);
}
}
}
}