Skip to content

Commit

Permalink
fix(rest): Added a commit message while create a moderation request.
Browse files Browse the repository at this point in the history
Signed-off-by: Nikesh kumar <[email protected]>
  • Loading branch information
Nikesh kumar committed Apr 16, 2024
1 parent 3746fa1 commit 798d2a2
Showing 1 changed file with 118 additions and 70 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -156,6 +156,7 @@

import static org.eclipse.sw360.datahandler.common.CommonUtils.wrapThriftOptionalReplacement;
import static org.eclipse.sw360.datahandler.common.WrappedException.wrapTException;
import static org.eclipse.sw360.datahandler.permissions.PermissionUtils.makePermission;
import static org.eclipse.sw360.rest.resourceserver.Sw360ResourceServer.REPORT_FILENAME_MAPPING;
import static org.springframework.hateoas.server.mvc.WebMvcLinkBuilder.linkTo;

Expand Down Expand Up @@ -183,6 +184,8 @@ public class ProjectController implements RepresentationModelProcessor<Repositor
.put(Project._Fields.RELEASE_RELATION_NETWORK, "dependencyNetwork").build();
private static final ImmutableMap<String, String> RESPONSE_BODY_FOR_MODERATION_REQUEST = ImmutableMap.<String, String>builder()
.put("message", "Moderation request is created").build();
private static final ImmutableMap<String, String> RESPONSE_BODY_FOR_MODERATION_REQUEST_WITH_COMMIT = ImmutableMap.<String, String>builder()
.put("message", "Unauthorized user or empty commit message passed.").build();
private static final List<String> enumReleaseRelationshipValues = Stream.of(ReleaseRelationship.values())
.map(ReleaseRelationship::name)
.collect(Collectors.toList());
Expand Down Expand Up @@ -659,7 +662,8 @@ public ResponseEntity linkToProjects(
// TODO: Add example for MAP value
}
)
@RequestBody List<String> projectIdsInRequestBody
@RequestBody List<String> projectIdsInRequestBody,
@RequestParam(value = "comment", required = false) String comment
) throws URISyntaxException, TException {

User sw360User = restControllerHelper.getSw360UserFromAuthentication();
Expand All @@ -674,32 +678,39 @@ public ResponseEntity linkToProjects(

try {

for(String projId: projectIdsInRequestBody) {
Project proj = projectService.getProjectForUserById(projId, sw360User);
Map<String, ProjectProjectRelationship> linkedProject= proj.getLinkedProjects();
for (String projId : projectIdsInRequestBody) {
Project proj = projectService.getProjectForUserById(projId, sw360User);
sw360User.setCommentMadeDuringModerationRequest(comment);
if (!isWriteActionAllowedOnProject(proj, sw360User) && comment == null) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST_WITH_COMMIT, HttpStatus.ACCEPTED);

if (proj.getLinkedProjects().keySet().contains(id)) {
alreadyLinkedIds.add(projId);
continue;
}
} else {
Map<String, ProjectProjectRelationship> linkedProject = proj.getLinkedProjects();

linkedProject.put(id, new ProjectProjectRelationship(ProjectRelationship.CONTAINED).setEnableSvm(sourceProj.isEnableSvm()));
proj.setLinkedProjects(linkedProject);
String cyclicLinkedProjectPath = projectService.getCyclicLinkedProjectPath(proj, sw360User);
if (!CommonUtils.isNullEmptyOrWhitespace(cyclicLinkedProjectPath)) {
idsWithCyclicPath.add(cyclicLinkedProjectPath);
continue;
}
if (proj.getLinkedProjects().keySet().contains(id)) {
alreadyLinkedIds.add(projId);
continue;
}

RequestStatus updatedstatus = projectService.updateProject(proj, sw360User);
if (updatedstatus == RequestStatus.SUCCESS) {
linkedProjectIds.add(projId);
}
linkedProject.put(id, new ProjectProjectRelationship(ProjectRelationship.CONTAINED)
.setEnableSvm(sourceProj.isEnableSvm()));
proj.setLinkedProjects(linkedProject);
String cyclicLinkedProjectPath = projectService.getCyclicLinkedProjectPath(proj, sw360User);
if (!CommonUtils.isNullEmptyOrWhitespace(cyclicLinkedProjectPath)) {
idsWithCyclicPath.add(cyclicLinkedProjectPath);
continue;
}

if (updatedstatus == RequestStatus.SENT_TO_MODERATOR) {
idsSentToModerator.add(projId);
}
}
RequestStatus updatedstatus = projectService.updateProject(proj, sw360User);
if (updatedstatus == RequestStatus.SUCCESS) {
linkedProjectIds.add(projId);
}

if (updatedstatus == RequestStatus.SENT_TO_MODERATOR) {
idsSentToModerator.add(projId);
}
}
}

if (!alreadyLinkedIds.isEmpty()) {
responseMap.put("Message regarding already linked project(s)", "Project ids are: " + alreadyLinkedIds);
Expand Down Expand Up @@ -735,6 +746,10 @@ public ResponseEntity linkToProjects(
return new ResponseEntity<>(responseResource, status);
}

private boolean isWriteActionAllowedOnProject(Project project, User user) {
return makePermission(project, user).isActionAllowed(RequestedAction.WRITE);
}

@PreAuthorize("hasAuthority('WRITE')")
@Operation(
summary = "Append new releases to existing releases in a project.",
Expand All @@ -752,14 +767,22 @@ public ResponseEntity patchReleases(
// TODO: Add example for MAP value
}
)
@RequestBody Object releaseURIs
) throws URISyntaxException, TException {
RequestStatus patchReleasesStatus = addOrPatchReleasesToProject(id, releaseURIs, true);
if (patchReleasesStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity<>(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(HttpStatus.CREATED);
}
@RequestBody Object releaseURIs,
@RequestParam(value = "comment", required = false) String comment
) throws URISyntaxException, TException {
final User sw360User = restControllerHelper.getSw360UserFromAuthentication();
Project project = projectService.getProjectForUserById(id, sw360User);
sw360User.setCommentMadeDuringModerationRequest(comment);
if (!isWriteActionAllowedOnProject(project, sw360User) && comment == null) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST_WITH_COMMIT, HttpStatus.ACCEPTED);
} else {
RequestStatus patchReleasesStatus = addOrPatchReleasesToProject(id, releaseURIs, true);
if (patchReleasesStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity<>(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(HttpStatus.CREATED);
}
}

@PreAuthorize("hasAuthority('WRITE')")
@Operation(
Expand All @@ -778,17 +801,25 @@ public ResponseEntity<?> linkPackages(
@Parameter(description = "Set of package IDs to be linked.",
example = "[\"3765276512\",\"5578999\",\"3765276513\"]"
)
@RequestBody Set<String> packagesInRequestBody
) throws URISyntaxException, TException {
if(!packageService.validatePackageIds(packagesInRequestBody)){
return new ResponseEntity<>("Package ID invalid! ", HttpStatus.NOT_FOUND);
}
RequestStatus linkPackageStatus = linkOrUnlinkPackages(id, packagesInRequestBody, true);
if (linkPackageStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity<>(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(HttpStatus.CREATED);
}
@RequestBody Set<String> packagesInRequestBody,
@RequestParam(value = "comment", required = false) String comment
) throws URISyntaxException, TException {
if (!packageService.validatePackageIds(packagesInRequestBody)) {
return new ResponseEntity<>("Package ID invalid! ", HttpStatus.NOT_FOUND);
}
final User sw360User = restControllerHelper.getSw360UserFromAuthentication();
Project project = projectService.getProjectForUserById(id, sw360User);
sw360User.setCommentMadeDuringModerationRequest(comment);
if (!isWriteActionAllowedOnProject(project, sw360User) && comment == null) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST_WITH_COMMIT, HttpStatus.ACCEPTED);
} else {
RequestStatus linkPackageStatus = linkOrUnlinkPackages(id, packagesInRequestBody, true);
if (linkPackageStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity<>(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(HttpStatus.CREATED);
}
}

@PreAuthorize("hasAuthority('WRITE')")
@Operation(
Expand All @@ -807,17 +838,25 @@ public ResponseEntity<?> patchPackages(
@Parameter(description = "Set of package IDs to be linked.",
example = "[\"3765276512\",\"5578999\",\"3765276513\"]"
)
@RequestBody Set<String> packagesInRequestBody
) throws URISyntaxException, TException {
if(!packageService.validatePackageIds(packagesInRequestBody)){
return new ResponseEntity<>("Package ID invalid! ", HttpStatus.NOT_FOUND);
}
RequestStatus patchPackageStatus = linkOrUnlinkPackages(id, packagesInRequestBody, false);
if (patchPackageStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity<>(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(HttpStatus.CREATED);
}
@RequestBody Set<String> packagesInRequestBody,
@RequestParam(value = "comment", required = false) String comment
) throws URISyntaxException, TException {
if (!packageService.validatePackageIds(packagesInRequestBody)) {
return new ResponseEntity<>("Package ID invalid! ", HttpStatus.NOT_FOUND);
}
final User sw360User = restControllerHelper.getSw360UserFromAuthentication();
Project project = projectService.getProjectForUserById(id, sw360User);
sw360User.setCommentMadeDuringModerationRequest(comment);
if (!isWriteActionAllowedOnProject(project, sw360User) && comment == null) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST_WITH_COMMIT, HttpStatus.ACCEPTED);
} else {
RequestStatus patchPackageStatus = linkOrUnlinkPackages(id, packagesInRequestBody, false);
if (patchPackageStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity<>(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(HttpStatus.CREATED);
}
}

@Operation(
description = "Get releases of a single project.",
Expand Down Expand Up @@ -1409,23 +1448,32 @@ public ResponseEntity<EntityModel<Project>> patchProject(
@PathVariable("id") String id,
@Parameter(description = "Updated values", schema = @Schema(implementation = Project.class))
@RequestBody Map<String, Object> reqBodyMap
) throws TException {
User user = restControllerHelper.getSw360UserFromAuthentication();
Project sw360Project = projectService.getProjectForUserById(id, user);
Project updateProject = convertToProject(reqBodyMap);
updateProject.unsetReleaseRelationNetwork();
sw360Project = this.restControllerHelper.updateProject(sw360Project, updateProject, reqBodyMap, mapOfProjectFieldsToRequestBody);
if (SW360Constants.ENABLE_FLEXIBLE_PROJECT_RELEASE_RELATIONSHIP && updateProject.getReleaseIdToUsage() != null) {
sw360Project.unsetReleaseRelationNetwork();
projectService.syncReleaseRelationNetworkAndReleaseIdToUsage(sw360Project, user);
}
RequestStatus updateProjectStatus = projectService.updateProject(sw360Project, user);
HalResource<Project> userHalResource = createHalProject(sw360Project, user);
if (updateProjectStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(userHalResource, HttpStatus.OK);
}
) throws TException {
User user = restControllerHelper.getSw360UserFromAuthentication();
Project sw360Project = projectService.getProjectForUserById(id, user);
Project updateProject = convertToProject(reqBodyMap);
updateProject.unsetReleaseRelationNetwork();
String comment = (String) reqBodyMap.get("comment");
user.setCommentMadeDuringModerationRequest(comment);

if (isWriteActionAllowedOnProject(updateProject, user) && comment == null) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST_WITH_COMMIT, HttpStatus.ACCEPTED);
} else {
sw360Project = this.restControllerHelper.updateProject(sw360Project, updateProject, reqBodyMap,
mapOfProjectFieldsToRequestBody);
if (SW360Constants.ENABLE_FLEXIBLE_PROJECT_RELEASE_RELATIONSHIP
&& updateProject.getReleaseIdToUsage() != null) {
sw360Project.unsetReleaseRelationNetwork();
projectService.syncReleaseRelationNetworkAndReleaseIdToUsage(sw360Project, user);
}
RequestStatus updateProjectStatus = projectService.updateProject(sw360Project, user);
HalResource<Project> userHalResource = createHalProject(sw360Project, user);
if (updateProjectStatus == RequestStatus.SENT_TO_MODERATOR) {
return new ResponseEntity(RESPONSE_BODY_FOR_MODERATION_REQUEST, HttpStatus.ACCEPTED);
}
return new ResponseEntity<>(userHalResource, HttpStatus.OK);
}
}

@Operation(
description = "Add attachments to a project.",
Expand Down

0 comments on commit 798d2a2

Please sign in to comment.