com.netgrif.application.engine.orgstructure.web.GroupController Maven / Gradle / Ivy
package com.netgrif.application.engine.orgstructure.web;
import com.netgrif.application.engine.orgstructure.groups.interfaces.INextGroupService;
import com.netgrif.application.engine.orgstructure.web.responsebodies.Group;
import com.netgrif.application.engine.orgstructure.web.responsebodies.GroupsResource;
import com.netgrif.application.engine.workflow.domain.Case;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.responses.ApiResponse;
import io.swagger.v3.oas.annotations.responses.ApiResponses;
import io.swagger.v3.oas.annotations.security.SecurityRequirement;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.hateoas.MediaTypes;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
@RestController
@RequestMapping("/api/group")
@ConditionalOnProperty(
value = "nae.group.web.enabled",
havingValue = "true",
matchIfMissing = true
)
@Tag(name = "Group")
public class GroupController {
private final INextGroupService service;
public GroupController(INextGroupService service) {
this.service = service;
}
@PreAuthorize("@authorizationService.hasAuthority('ADMIN')")
@Operation(summary = "Get all groups in the system",
description = "Caller must have the ADMIN role",
security = {@SecurityRequirement(name = "BasicAuth")})
@GetMapping(value = "/all", produces = MediaTypes.HAL_JSON_VALUE)
@ApiResponses(value = {
@ApiResponse(responseCode = "200", description = "OK"),
@ApiResponse(responseCode = "403", description = "Caller doesn't fulfill the authorisation requirements"),
})
public GroupsResource getAllGroups() {
List groups = service.findAllGroups();
Set groupResponse = groups.stream()
.map(aCase -> new Group(aCase.getStringId(), aCase.getTitle()))
.collect(Collectors.toCollection(HashSet::new));
return new GroupsResource(groupResponse);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy