use of com.mercedesbenz.sechub.domain.administration.user.User in project sechub by mercedes-benz.
the class ProjectChangeOwnerServiceTest method assign_same_owner_to_project__throws_already_exists_exception.
@Test
public void assign_same_owner_to_project__throws_already_exists_exception() {
User oldOwner = mock(User.class);
/* prepare */
Project project1 = new Project();
project1.id = "project1";
project1.owner = oldOwner;
when(projectRepository.findOrFailProject("project1")).thenReturn(project1);
when(oldOwner.getName()).thenReturn("old");
when(userRepository.findOrFailUser("old")).thenReturn(oldOwner);
/* execute */
/* test */
assertThrows(AlreadyExistsException.class, () -> {
serviceToTest.changeProjectOwner(oldOwner.getName(), project1.getId());
});
}
use of com.mercedesbenz.sechub.domain.administration.user.User in project sechub by mercedes-benz.
the class ProjectTransactionService method saveInOwnTransaction.
/**
* Persists a project, users and project meta data in same (new) transaction
*
* @param project
* @param users
* @return persisted project
*/
@Transactional(propagation = Propagation.REQUIRES_NEW)
public Project saveInOwnTransaction(Project project, User... users) {
requireNonNull(project, "Project may not be null!");
requireNonNull(users, "User may not be null!");
/* store */
Project savedProject = projectRepository.save(project);
LOG.debug("Saved project:{}", savedProject.getId());
metaDataRepository.saveAll(project.metaData);
LOG.debug("Saved metadata for project:{}", savedProject.getId());
for (User user : users) {
User savedUser = userRepository.save(user);
LOG.debug("Saved user:{}", savedUser.getName());
}
return savedProject;
}
use of com.mercedesbenz.sechub.domain.administration.user.User in project sechub by mercedes-benz.
the class ProjectUnassignUserService method unassignUserFromProject.
/* @formatter:off */
@UseCaseAdminUnassignsUserFromProject(@Step(number = 2, name = "Unassign user", description = "The service will remove the user to the project. If users has no longer access to projects ROLE_USER will be removed"))
public /* @formatter:on */
void unassignUserFromProject(String userId, String projectId) {
auditLogService.log("triggers unassignment of user:{} to project:{}", logSanitizer.sanitize(userId, 30), logSanitizer.sanitize(projectId, 30));
assertion.assertIsValidUserId(userId);
assertion.assertIsValidProjectId(projectId);
Project project = projectRepository.findOrFailProject(projectId);
User user = userRepository.findOrFailUser(userId);
if (!project.getUsers().remove(user)) {
throw new AlreadyExistsException("User already not assigned to this project!");
}
user.getProjects().remove(project);
transactionService.saveInOwnTransaction(project, user);
sendUserRemovedFromProjectEvent(projectId, user);
sendRequestUserRoleRecalculation(user);
}
use of com.mercedesbenz.sechub.domain.administration.user.User in project sechub by mercedes-benz.
the class JobRestartRequestService method buildMessage.
private JobMessage buildMessage(UUID jobUUID) {
JobMessage message = new JobMessage();
message.setJobUUID(jobUUID);
JobInformation probe = new JobInformation();
probe.setJobUUID(jobUUID);
Example<JobInformation> example = Example.of(probe);
Optional<JobInformation> optJobInfo = repository.findOne(example);
if (!optJobInfo.isPresent()) {
LOG.warn("Did not found job information, so not able to resolve owner email address");
return message;
}
JobInformation jobInfo = optJobInfo.get();
if (jobInfo.owner == null) {
LOG.warn("Did not found owner inside job information, so not able to resolve owner email address");
return message;
}
Optional<User> optUser = userRepository.findById(jobInfo.owner);
if (!optUser.isPresent()) {
LOG.warn("Did not found owner {} inside user repo, so not able to resolve owner email address", jobInfo.owner);
return message;
}
message.setOwner(jobInfo.owner);
message.setOwnerEmailAddress(optUser.get().getEmailAdress());
return message;
}
use of com.mercedesbenz.sechub.domain.administration.user.User in project sechub by mercedes-benz.
the class ProjectAdministrationRestControllerRestDocTest method restdoc_show_project_details.
@Test
@UseCaseRestDoc(useCase = UseCaseAdminShowsProjectDetails.class)
public void restdoc_show_project_details() throws Exception {
/* prepare */
String apiEndpoint = https(PORT_USED).buildAdminShowsProjectDetailsUrl(PROJECT_ID.pathElement());
Class<? extends Annotation> useCase = UseCaseAdminShowsProjectDetails.class;
Project project = mock(Project.class);
when(project.getId()).thenReturn("projectId1");
when(project.getAccessLevel()).thenReturn(ProjectAccessLevel.FULL);
Set<User> users = new LinkedHashSet<>();
User user1 = mock(User.class);
when(user1.getName()).thenReturn("name1");
User user2 = mock(User.class);
when(user2.getName()).thenReturn("name2");
users.add(user1);
users.add(user2);
when(project.getUsers()).thenReturn(users);
when(project.getOwner()).thenReturn(user1);
Set<URI> whiteList = new LinkedHashSet<>();
whiteList.add(new URI("http://www.sechub.example.org"));
whiteList.add(new URI("http://www.sechub.example.com"));
when(project.getWhiteList()).thenReturn(whiteList);
Set<ProjectMetaDataEntity> metaData = new LinkedHashSet<>();
ProjectMetaDataEntity entry = new ProjectMetaDataEntity("projectId1", "key1", "value1");
metaData.add(entry);
when(project.getMetaData()).thenReturn(metaData);
when(project.getDescription()).thenReturn("description");
ProjectDetailInformation detailInformation = new ProjectDetailInformation(project);
when(detailInformationService.fetchDetails("projectId1")).thenReturn(detailInformation);
/* execute + test @formatter:off */
this.mockMvc.perform(get(apiEndpoint, "projectId1").contentType(MediaType.APPLICATION_JSON_VALUE)).andDo(print()).andExpect(status().isOk()).andDo(defineRestService().with().useCaseData(useCase).tag(RestDocFactory.extractTag(apiEndpoint)).responseSchema(OpenApiSchema.PROJECT_DETAILS.getSchema()).and().document(pathParameters(parameterWithName(PROJECT_ID.paramName()).description("The id for project to show details for")), responseFields(fieldWithPath(ProjectDetailInformation.PROPERTY_PROJECT_ID).description("The name of the project"), fieldWithPath(ProjectDetailInformation.PROPERTY_USERS).description("A list of all users having access to the project"), fieldWithPath(ProjectDetailInformation.PROPERTY_OWNER).description("Username of the owner of this project. An owner is the person in charge."), fieldWithPath(ProjectDetailInformation.PROPERTY_WHITELIST).description("A list of all whitelisted URIs. Only these ones can be scanned for the project!"), fieldWithPath(ProjectDetailInformation.PROPERTY_METADATA).description("An JSON object containing metadata key-value pairs defined for this project."), fieldWithPath(ProjectDetailInformation.PROPERTY_METADATA + ".key1").description("An arbitrary metadata key"), fieldWithPath(ProjectDetailInformation.PROPERTY_ACCESSLEVEL).description("The project access level"), fieldWithPath(ProjectDetailInformation.PROPERTY_DESCRIPTION).description("The project description."))));
/* @formatter:on */
}
Aggregations