Massimiliano Assante 2019-05-06 15:34:14 +00:00
parent 372605d175
commit 7c58db8e8b
1 changed files with 46 additions and 38 deletions

View File

@ -135,8 +135,7 @@ public class VREAccessesHarvester extends BasicHarvester {
AnalyticsReportCredentials credentialsFromD4S = getAuthorisedApplicationInfoFromIs(); AnalyticsReportCredentials credentialsFromD4S = getAuthorisedApplicationInfoFromIs();
AnalyticsReporting service = initializeAnalyticsReporting(credentialsFromD4S); AnalyticsReporting service = initializeAnalyticsReporting(credentialsFromD4S);
HashMap<String,GetReportsResponse> responses = getReportResponses(service, credentialsFromD4S.getViewIds(), HashMap<String,List<GetReportsResponse>> responses = getReportResponses(service, credentialsFromD4S.getViewIds(), dateRange);
dateRange);
List<VREAccessesReportRow> totalAccesses = new ArrayList<>(); List<VREAccessesReportRow> totalAccesses = new ArrayList<>();
for(String view : responses.keySet()) { for(String view : responses.keySet()) {
@ -172,30 +171,38 @@ public class VREAccessesHarvester extends BasicHarvester {
* @return GetReportResponse The Analytics Reporting API V4 response. * @return GetReportResponse The Analytics Reporting API V4 response.
* @throws IOException * @throws IOException
*/ */
private static HashMap<String,GetReportsResponse> getReportResponses(AnalyticsReporting service, private static HashMap<String,List<GetReportsResponse>> getReportResponses(AnalyticsReporting service,
List<String> viewIDs, DateRange dateRange) throws IOException { List<String> viewIDs, DateRange dateRange) throws IOException {
HashMap<String,GetReportsResponse> reports = new HashMap<>(); HashMap<String,List<GetReportsResponse>> reports = new HashMap<>();
// Create the Metrics object. // Create the Metrics object.
Metric sessions = new Metric().setExpression("ga:pageviews").setAlias("pages"); Metric sessions = new Metric().setExpression("ga:pageviews").setAlias("pages");
com.google.api.services.analyticsreporting.v4.model.Dimension pageTitle = new com.google.api.services.analyticsreporting.v4.model.Dimension().setName("ga:pagePath"); com.google.api.services.analyticsreporting.v4.model.Dimension pageTitle = new com.google.api.services.analyticsreporting.v4.model.Dimension().setName("ga:pagePath");
for(String view : viewIDs) { for(String view : viewIDs) {
List<GetReportsResponse> gReportResponses = new ArrayList<>();
logger.info("Getting data from Google Analytics for viewid: " + view); logger.info("Getting data from Google Analytics for viewid: " + view);
boolean iterateMorePages = true;
String nextPageToken = null;
while (iterateMorePages) {
// Create the ReportRequest object. // Create the ReportRequest object.
ReportRequest request = new ReportRequest().setViewId(view.trim()).setDateRanges(Arrays.asList(dateRange)) ReportRequest request = new ReportRequest().setViewId(view.trim()).setDateRanges(Arrays.asList(dateRange))
.setMetrics(Arrays.asList(sessions)).setDimensions(Arrays.asList(pageTitle)); .setMetrics(Arrays.asList(sessions)).setDimensions(Arrays.asList(pageTitle));
request.setPageSize(1000);
request.setPageToken(nextPageToken);
ArrayList<ReportRequest> requests = new ArrayList<ReportRequest>(); ArrayList<ReportRequest> requests = new ArrayList<ReportRequest>();
requests.add(request); requests.add(request);
// Create the GetReportsRequest object. // Create the GetReportsRequest object.
GetReportsRequest getReport = new GetReportsRequest().setReportRequests(requests); GetReportsRequest getReport = new GetReportsRequest().setReportRequests(requests);
// Call the batchGet method. // Call the batchGet method.
GetReportsResponse response = service.reports().batchGet(getReport).execute(); GetReportsResponse response = service.reports().batchGet(getReport).execute();
reports.put(view, response); nextPageToken = response.getReports().get(0).getNextPageToken();
iterateMorePages = (nextPageToken != null);
logger.debug("got nextPageToken: "+nextPageToken);
gReportResponses.add(response);
}
reports.put(view, gReportResponses);
} }
// Return the response. // Return the response.
return reports; return reports;
@ -211,11 +218,11 @@ public class VREAccessesHarvester extends BasicHarvester {
* *
* @param response An Analytics Reporting API V4 response. * @param response An Analytics Reporting API V4 response.
*/ */
private static List<VREAccessesReportRow> parseResponse(String viewId, GetReportsResponse response) { private static List<VREAccessesReportRow> parseResponse(String viewId, List<GetReportsResponse> responses) {
logger.debug("parsing Response for " + viewId); logger.debug("parsing Response for " + viewId);
List<VREAccessesReportRow> toReturn = new ArrayList<>(); List<VREAccessesReportRow> toReturn = new ArrayList<>();
for (GetReportsResponse response : responses) {
for (Report report: response.getReports()) { for (Report report: response.getReports()) {
List<ReportRow> rows = report.getData().getRows(); List<ReportRow> rows = report.getData().getRows();
if (rows == null) { if (rows == null) {
@ -239,6 +246,7 @@ public class VREAccessesHarvester extends BasicHarvester {
} }
} }
} }
}
return toReturn; return toReturn;
} }