use of eu.bcvsolutions.idm.core.api.dto.IdmRequestDto in project CzechIdMng by bcvsolutions.
the class RequestManagerTest method createRequest.
private IdmRequestDto createRequest(IdmRoleDto changedRole) {
IdmRequestDto request = requestManager.createRequest(changedRole);
Assert.assertNotNull(request);
Assert.assertEquals(request.getOwnerType(), changedRole.getClass().getName());
Assert.assertEquals(request.getOwnerId(), changedRole.getId());
// Change role (without save)
changedRole.setDescription(getHelper().createName());
changedRole.setPriority(1000);
// Create request item
IdmRoleDto requestable = requestManager.post(request.getId(), changedRole);
Assert.assertNotNull(requestable);
Assert.assertNotNull(requestable.getRequestItem());
// Is not same instance
Assert.assertNotSame(changedRole, requestable);
// Has same values as new role
Assert.assertEquals(changedRole.getPriority(), requestable.getPriority());
Assert.assertEquals(changedRole.getDescription(), requestable.getDescription());
IdmRoleDto currentRole = roleService.get(changedRole.getId());
Assert.assertNotEquals(changedRole.getPriority(), currentRole.getPriority());
Assert.assertNotEquals(changedRole.getDescription(), currentRole.getDescription());
return request;
}
use of eu.bcvsolutions.idm.core.api.dto.IdmRequestDto in project CzechIdMng by bcvsolutions.
the class RequestManagerTest method testGetChangesEAV.
@Test
public void testGetChangesEAV() {
// Create role
IdmRoleDto role = getHelper().createRole();
// Get definition
IdmFormInstanceDto formInstance = formService.getFormInstance(role);
// None values yet
Assert.assertEquals(0, formInstance.getValues().size());
IdmFormDefinitionDto formDefinition = formInstance.getFormDefinition();
// Create form attributes
IdmFormAttributeDto attributeShortText = new IdmFormAttributeDto();
attributeShortText.setCode(getHelper().createName());
attributeShortText.setName(attributeShortText.getCode());
attributeShortText.setPersistentType(PersistentType.SHORTTEXT);
attributeShortText.setFormDefinition(formDefinition.getId());
attributeShortText = formService.saveAttribute(attributeShortText);
IdmFormAttributeDto attributeBoolean = new IdmFormAttributeDto();
attributeBoolean.setCode(getHelper().createName());
attributeBoolean.setName(attributeBoolean.getCode());
attributeBoolean.setPersistentType(PersistentType.BOOLEAN);
attributeBoolean.setFormDefinition(formDefinition.getId());
attributeBoolean = formService.saveAttribute(attributeBoolean);
IdmFormAttributeDto attributeConfidential = new IdmFormAttributeDto();
attributeConfidential.setCode(getHelper().createName());
attributeConfidential.setName(attributeConfidential.getCode());
attributeConfidential.setPersistentType(PersistentType.SHORTTEXT);
attributeConfidential.setConfidential(true);
attributeConfidential.setFormDefinition(formDefinition.getId());
attributeConfidential = formService.saveAttribute(attributeConfidential);
IdmFormAttributeDto attributeInt = new IdmFormAttributeDto();
attributeInt.setCode(getHelper().createName());
attributeInt.setName(attributeInt.getCode());
attributeInt.setPersistentType(PersistentType.INT);
attributeInt.setFormDefinition(formDefinition.getId());
attributeInt = formService.saveAttribute(attributeInt);
// Create request
IdmRequestDto request = requestManager.createRequest(role);
Assert.assertNotNull(request);
IdmFormInstanceDto formInstanceRequest = requestManager.getFormInstance(request.getId(), role, formDefinition);
// None values yet
Assert.assertEquals(0, formInstanceRequest.getValues().size());
IdmFormValueDto valueShortText = new IdmFormValueDto(attributeShortText);
valueShortText.setValue(getHelper().createName());
formInstanceRequest.getValues().add(valueShortText);
IdmFormValueDto valueBoolean = new IdmFormValueDto(attributeBoolean);
valueBoolean.setValue(true);
formInstanceRequest.getValues().add(valueBoolean);
IdmFormValueDto valueConfidential = new IdmFormValueDto(attributeConfidential);
String confidentialValueString = getHelper().createName();
valueConfidential.setValue(confidentialValueString);
formInstanceRequest.getValues().add(valueConfidential);
IdmFormValueDto valueInt = new IdmFormValueDto(attributeInt);
valueInt.setValue(111);
formInstanceRequest.getValues().add(valueInt);
formDefinition = formService.getDefinition(IdmRoleDto.class);
requestManager.saveFormInstance(request.getId(), role, formDefinition, formInstanceRequest.getValues());
formInstanceRequest = requestManager.getFormInstance(request.getId(), role, formDefinition);
// Four values in request
Assert.assertEquals(4, formInstanceRequest.getValues().size());
formInstance = formService.getFormInstance(role);
// None values via standard service
Assert.assertEquals(0, formInstance.getValues().size());
formInstanceRequest.getValues().forEach(value -> {
IdmRequestItemDto item = DtoUtils.getEmbedded(value, Requestable.REQUEST_ITEM_FIELD, IdmRequestItemDto.class);
IdmRequestItemChangesDto changes = requestManager.getChanges(item);
Assert.assertNotNull(changes);
List<IdmRequestItemAttributeDto> attributes = changes.getAttributes();
attributes.forEach(attribute -> {
Assert.assertEquals(RequestOperationType.ADD, attribute.getValue().getChange());
});
IdmRequestItemAttributeDto attributeDto = attributes.stream().filter(attribute -> "stringValue".equals(attribute.getName())).findFirst().get();
Assert.assertEquals(value.getStringValue(), attributeDto.getValue().getValue());
attributeDto = attributes.stream().filter(attribute -> "booleanValue".equals(attribute.getName())).findFirst().get();
Assert.assertEquals(value.getBooleanValue(), attributeDto.getValue().getValue());
attributeDto = attributes.stream().filter(attribute -> "doubleValue".equals(attribute.getName())).findFirst().get();
Assert.assertEquals(value.getDoubleValue(), attributeDto.getValue().getValue());
attributeDto = attributes.stream().filter(attribute -> "longValue".equals(attribute.getName())).findFirst().get();
Assert.assertEquals(value.getLongValue(), attributeDto.getValue().getValue());
attributeDto = attributes.stream().filter(attribute -> "shortTextValue".equals(attribute.getName())).findFirst().get();
Assert.assertEquals(value.getShortTextValue(), attributeDto.getValue().getValue());
});
request = requestManager.startRequest(request.getId(), true);
Assert.assertEquals(RequestState.EXECUTED, request.getState());
formInstance = formService.getFormInstance(role);
// Four values via standard service
Assert.assertEquals(4, formInstance.getValues().size());
// All changes was applied, check on none changes
formInstanceRequest = requestManager.getFormInstance(request.getId(), role, formDefinition);
formInstanceRequest.getValues().forEach(value -> {
IdmRequestItemDto item = DtoUtils.getEmbedded(value, Requestable.REQUEST_ITEM_FIELD, IdmRequestItemDto.class);
IdmRequestItemChangesDto changes = requestManager.getChanges(item);
Assert.assertNotNull(changes);
List<IdmRequestItemAttributeDto> attributes = changes.getAttributes();
attributes.forEach(attribute -> {
Assert.assertEquals(attribute.getValue().getOldValue(), attribute.getValue().getValue());
});
});
// Make changes
final UUID attributeShortTextId = attributeShortText.getId();
IdmFormValueDto changedValueShortText = new IdmFormValueDto(attributeShortText);
changedValueShortText.setValue(getHelper().createName());
// Create new request
IdmRequestDto requestChange = requestManager.createRequest(role);
Assert.assertNotNull(requestChange);
// Create request items
requestManager.saveFormInstance(requestChange.getId(), role, formDefinition, Lists.newArrayList(changedValueShortText));
formInstanceRequest = requestManager.getFormInstance(requestChange.getId(), role, formDefinition);
// One change in the request
Assert.assertEquals(4, formInstanceRequest.getValues().size());
IdmFormValueDto changedValueShortTextRequest = formInstanceRequest.getValues().stream().filter(value -> value.getFormAttribute().equals(attributeShortTextId)).findFirst().get();
IdmRequestItemDto item = DtoUtils.getEmbedded(changedValueShortTextRequest, Requestable.REQUEST_ITEM_FIELD, IdmRequestItemDto.class);
IdmRequestItemChangesDto changes = requestManager.getChanges(item);
Assert.assertNotNull(changes);
List<IdmRequestItemAttributeDto> attributes = changes.getAttributes();
IdmRequestItemAttributeDto attributeDto = attributes.stream().filter(attribute -> "shortTextValue".equals(attribute.getName())).findFirst().get();
Assert.assertNotEquals(attributeDto.getValue().getOldValue(), attributeDto.getValue().getValue());
Assert.assertEquals(changedValueShortText.getShortTextValue(), attributeDto.getValue().getValue());
// Delete attributes
formService.deleteValues(role, attributeShortText);
formService.deleteAttribute(attributeShortText);
formService.deleteValues(role, attributeBoolean);
formService.deleteAttribute(attributeBoolean);
formService.deleteValues(role, attributeConfidential);
formService.deleteAttribute(attributeConfidential);
formService.deleteValues(role, attributeInt);
formService.deleteAttribute(attributeInt);
}
use of eu.bcvsolutions.idm.core.api.dto.IdmRequestDto in project CzechIdMng by bcvsolutions.
the class RequestManagerTest method testDeleteRequest.
@Test
public void testDeleteRequest() {
// Create role
IdmRoleDto changedRole = getHelper().createRole();
// Create request
IdmRequestDto request = requestManager.createRequest(changedRole);
Assert.assertNotNull(request);
Assert.assertEquals(request.getOwnerType(), changedRole.getClass().getName());
Assert.assertEquals(request.getOwnerId(), changedRole.getId());
// Change role (without save)
changedRole.setDescription(getHelper().createName());
changedRole.setPriority(1000);
// Create request item
Requestable requestable = requestManager.post(request.getId(), changedRole);
Assert.assertNotNull(requestable);
Assert.assertNotNull(requestable.getRequestItem());
Assert.assertTrue(requestable instanceof IdmRoleDto);
IdmRoleDto roleFromRequest = (IdmRoleDto) requestable;
// Is not same instance
Assert.assertTrue(changedRole != roleFromRequest);
// Has same values as new role
Assert.assertEquals(changedRole.getPriority(), roleFromRequest.getPriority());
Assert.assertEquals(changedRole.getDescription(), roleFromRequest.getDescription());
IdmRoleDto currentRole = roleService.get(changedRole.getId());
Assert.assertNotEquals(changedRole.getPriority(), currentRole.getPriority());
Assert.assertNotEquals(changedRole.getDescription(), currentRole.getDescription());
Assert.assertNotNull(requestItemService.get(requestable.getRequestItem()));
// Delete the request
requestService.delete(request);
// Request item must be canceled
IdmRequestItemDto requestItem = requestItemService.get(requestable.getRequestItem());
Assert.assertNull(requestItem);
// Request must be canceled
request = requestService.get(request.getId());
Assert.assertNull(request);
}
use of eu.bcvsolutions.idm.core.api.dto.IdmRequestDto in project CzechIdMng by bcvsolutions.
the class RequestManagerTest method testChangeRoleWithGuaranteeTypeByRole.
@Test
public void testChangeRoleWithGuaranteeTypeByRole() {
// Guarantee type -> set to null (default value).
getHelper().setConfigurationValue("idm.sec.core.request.idm-role.approval.guarantee-type", null);
String guaranteeTypeOne = getHelper().createName();
String guaranteeTypeTwo = getHelper().createName();
// Create role with guarantee
IdmIdentityDto guaranteeOne = getHelper().createIdentity();
IdmIdentityDto guaranteeTwo = getHelper().createIdentity();
IdmRoleDto roleOne = getHelper().createRole();
IdmRoleDto roleTwo = getHelper().createRole();
getHelper().createIdentityRole(guaranteeOne, roleOne);
getHelper().createIdentityRole(guaranteeTwo, roleTwo);
IdmRoleDto changedRole = getHelper().createRole();
getHelper().createRoleGuaranteeRole(changedRole, roleOne, guaranteeTypeOne);
getHelper().createRoleGuaranteeRole(changedRole, roleTwo, guaranteeTypeTwo);
// Create request
IdmRequestDto request = createRequest(changedRole);
// Start request
IdmRequestDto executedRequest = requestManager.startRequest(request.getId(), true);
Assert.assertNotNull(executedRequest);
executedRequest = requestService.get(executedRequest.getId());
// Role has guarantee, approval process must be started
Assert.assertEquals(RequestState.IN_PROGRESS, executedRequest.getState());
WorkflowFilterDto taskFilter = new WorkflowFilterDto();
taskFilter.setProcessInstanceId(executedRequest.getWfProcessId());
List<WorkflowTaskInstanceDto> tasks = workflowTaskInstanceService.find(taskFilter, null).getContent();
Assert.assertEquals(1, tasks.size());
WorkflowTaskInstanceDto workflowTaskInstanceDto = tasks.get(0);
List<IdentityLinkDto> candidates = workflowTaskInstanceDto.getIdentityLinks().stream().filter(identityLinkDto -> IdentityLinkType.CANDIDATE.equals(identityLinkDto.getType())).collect(Collectors.toList());
Assert.assertEquals(2, candidates.size());
Assert.assertTrue(candidates.stream().anyMatch(candidate -> guaranteeOne.getId().toString().equals(candidate.getUserId())));
Assert.assertTrue(candidates.stream().anyMatch(candidate -> guaranteeTwo.getId().toString().equals(candidate.getUserId())));
// Guarantee type -> set to guaranteeTypeOne.
getHelper().setConfigurationValue("idm.sec.core.request.idm-role.approval.guarantee-type", guaranteeTypeOne);
// Create request for guarantee type ONE.
request = createRequest(changedRole);
// Start request
executedRequest = requestManager.startRequest(request.getId(), true);
Assert.assertNotNull(executedRequest);
executedRequest = requestService.get(executedRequest.getId());
// Role has guarantee, approval process must be started
Assert.assertEquals(RequestState.IN_PROGRESS, executedRequest.getState());
taskFilter = new WorkflowFilterDto();
taskFilter.setProcessInstanceId(executedRequest.getWfProcessId());
tasks = workflowTaskInstanceService.find(taskFilter, null).getContent();
Assert.assertEquals(1, tasks.size());
workflowTaskInstanceDto = tasks.get(0);
candidates = workflowTaskInstanceDto.getIdentityLinks().stream().filter(identityLinkDto -> IdentityLinkType.CANDIDATE.equals(identityLinkDto.getType())).collect(Collectors.toList());
Assert.assertEquals(1, candidates.size());
Assert.assertTrue(candidates.stream().anyMatch(candidate -> guaranteeOne.getId().toString().equals(candidate.getUserId())));
// Guarantee type -> set to guaranteeTypeTwo.
getHelper().setConfigurationValue("idm.sec.core.request.idm-role.approval.guarantee-type", guaranteeTypeTwo);
// Create request for guarantee type TWO.
request = createRequest(changedRole);
// Start request
executedRequest = requestManager.startRequest(request.getId(), true);
Assert.assertNotNull(executedRequest);
executedRequest = requestService.get(executedRequest.getId());
// Role has guarantee, approval process must be started
Assert.assertEquals(RequestState.IN_PROGRESS, executedRequest.getState());
taskFilter = new WorkflowFilterDto();
requestService.get(executedRequest.getId());
taskFilter.setProcessInstanceId(executedRequest.getWfProcessId());
tasks = workflowTaskInstanceService.find(taskFilter, null).getContent();
Assert.assertEquals(1, tasks.size());
workflowTaskInstanceDto = tasks.get(0);
candidates = workflowTaskInstanceDto.getIdentityLinks().stream().filter(identityLinkDto -> IdentityLinkType.CANDIDATE.equals(identityLinkDto.getType())).collect(Collectors.toList());
Assert.assertEquals(1, candidates.size());
Assert.assertTrue(candidates.stream().anyMatch(candidate -> guaranteeTwo.getId().toString().equals(candidate.getUserId())));
// Clear after test:
// Guarantee type -> set to null (default value).
getHelper().setConfigurationValue("idm.sec.core.request.idm-role.approval.guarantee-type", null);
}
use of eu.bcvsolutions.idm.core.api.dto.IdmRequestDto in project CzechIdMng by bcvsolutions.
the class RequestApprovalProcessor method process.
@SuppressWarnings("unchecked")
@Override
public EventResult<IdmRequestDto> process(EntityEvent<IdmRequestDto> event) {
IdmRequestDto dto = event.getContent();
boolean checkRight = (boolean) event.getProperties().get(CHECK_RIGHT_PROPERTY);
//
String ownerTyp = dto.getOwnerType();
Assert.notNull(ownerTyp, "Owner type is rquired for start approval process!");
Class<Requestable> ownerClass = null;
try {
ownerClass = (Class<Requestable>) Class.forName(ownerTyp);
} catch (ClassNotFoundException e) {
throw new CoreException(e);
}
String wfDefinition = requestConfiguration.getRequestApprovalProcessKey(ownerClass);
if (Strings.isNullOrEmpty(wfDefinition)) {
throw new ResultCodeException(CoreResultCode.REQUEST_NO_WF_DEF_FOUND, ImmutableMap.of("entityType", dto.getOwnerType()));
}
boolean approved = manager.startApprovalProcess(dto, checkRight, event, wfDefinition);
DefaultEventResult<IdmRequestDto> result = new DefaultEventResult<>(event, this);
result.setSuspended(!approved);
return result;
}
Aggregations