com.synopsys.integration.blackduck.codelocation.CodeLocationWaitJobCondition Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of blackduck-common Show documentation
Show all versions of blackduck-common Show documentation
A library for using various capabilities of Black Duck, notably the REST API and signature scanning.
/*
* blackduck-common
*
* Copyright (c) 2021 Synopsys, Inc.
*
* Use subject to the terms and conditions of the Synopsys End User Software License and Maintenance Agreement. All rights reserved worldwide.
*/
package com.synopsys.integration.blackduck.codelocation;
import java.util.Arrays;
import java.util.Date;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.stream.Collectors;
import com.synopsys.integration.blackduck.api.generated.view.ProjectVersionView;
import com.synopsys.integration.blackduck.api.generated.view.UserView;
import com.synopsys.integration.blackduck.api.manual.enumeration.NotificationType;
import com.synopsys.integration.blackduck.api.manual.view.NotificationUserView;
import com.synopsys.integration.blackduck.api.manual.view.VersionBomCodeLocationBomComputedNotificationUserView;
import com.synopsys.integration.blackduck.service.BlackDuckApiClient;
import com.synopsys.integration.blackduck.service.dataservice.NotificationService;
import com.synopsys.integration.blackduck.service.dataservice.ProjectService;
import com.synopsys.integration.blackduck.service.model.NotificationTaskRange;
import com.synopsys.integration.blackduck.service.model.ProjectVersionWrapper;
import com.synopsys.integration.blackduck.service.request.NotificationEditor;
import com.synopsys.integration.exception.IntegrationException;
import com.synopsys.integration.log.IntLogger;
import com.synopsys.integration.util.NameVersion;
import com.synopsys.integration.wait.WaitJobCondition;
public class CodeLocationWaitJobCondition implements WaitJobCondition {
private final IntLogger logger;
private final ProjectService projectService;
private final NotificationService notificationService;
private final UserView userView;
private final NotificationTaskRange notificationTaskRange;
private final NameVersion projectAndVersion;
private final Set codeLocationNames;
private final int expectedNotificationCount;
private final CodeLocationsRetriever codeLocationsRetriever;
private final Set foundCodeLocationNames = new HashSet<>();
public CodeLocationWaitJobCondition(IntLogger logger, BlackDuckApiClient blackDuckApiClient, ProjectService projectService, NotificationService notificationService, UserView userView, NotificationTaskRange notificationTaskRange,
NameVersion projectAndVersion, Set codeLocationNames, int expectedNotificationCount) {
this.logger = logger;
this.projectService = projectService;
this.notificationService = notificationService;
this.userView = userView;
this.notificationTaskRange = notificationTaskRange;
this.projectAndVersion = projectAndVersion;
this.codeLocationNames = codeLocationNames;
this.expectedNotificationCount = expectedNotificationCount;
codeLocationsRetriever = new CodeLocationsRetriever(blackDuckApiClient);
}
@Override
public boolean isComplete() throws IntegrationException {
int actualNotificationCount = retrieveCompletedCount(userView, notificationTaskRange);
boolean complete = foundCodeLocationNames.containsAll(codeLocationNames) && actualNotificationCount >= expectedNotificationCount;
if (!complete) {
logger.info("All code locations have not been added to the BOM yet...");
}
return complete;
}
public Set getFoundCodeLocationNames() {
return foundCodeLocationNames;
}
private int retrieveCompletedCount(UserView userView, NotificationTaskRange notificationTaskRange) throws IntegrationException {
Optional projectVersionWrapper = projectService.getProjectVersion(projectAndVersion);
if (!projectVersionWrapper.isPresent()) {
return 0;
}
ProjectVersionView projectVersionView = projectVersionWrapper.get().getProjectVersionView();
Map foundCodeLocations = codeLocationsRetriever.retrieveCodeLocations(projectVersionView, codeLocationNames);
int actualNotificationCount = 0;
if (foundCodeLocations.size() > 0) {
logger.debug("At least one code location has been found, now looking for notifications.");
List notifications = getFilteredNotificationUserViews(userView, notificationTaskRange);
logger.debug(String.format("There were %d notifications found.", notifications.size()));
for (VersionBomCodeLocationBomComputedNotificationUserView notification : notifications) {
String codeLocationUrl = notification.getContent().getCodeLocation();
if (foundCodeLocations.containsKey(codeLocationUrl)) {
String codeLocationName = foundCodeLocations.get(codeLocationUrl);
foundCodeLocationNames.add(codeLocationName);
actualNotificationCount++;
logger.info(String.format("Found %s code location (%d of %d).", codeLocationName, actualNotificationCount, expectedNotificationCount));
}
}
}
return actualNotificationCount;
}
private List getFilteredNotificationUserViews(UserView userView, NotificationTaskRange notificationTaskRange) throws IntegrationException {
Date startDate = notificationTaskRange.getStartDate();
Date endDate = notificationTaskRange.getEndDate();
List typesToInclude = Arrays.asList(NotificationType.VERSION_BOM_CODE_LOCATION_BOM_COMPUTED.name());
NotificationEditor notificationEditor = new NotificationEditor(startDate, endDate, typesToInclude);
List notifications = notificationService.getAllUserNotifications(userView, notificationEditor);
return notifications
.stream()
.map(VersionBomCodeLocationBomComputedNotificationUserView.class::cast)
.collect(Collectors.toList());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy