use of com.evolveum.midpoint.audit.api.AuditEventRecord in project midpoint by Evolveum.
the class PrimaryChangeProcessor method prepareProcessInstanceAuditRecord.
//endregion
//region Auditing
@Override
public AuditEventRecord prepareProcessInstanceAuditRecord(WfTask wfTask, AuditEventStage stage, Map<String, Object> variables, OperationResult result) {
AuditEventRecord auditEventRecord = baseAuditHelper.prepareProcessInstanceAuditRecord(wfTask, stage, result);
ObjectTreeDeltas<?> deltas;
try {
if (stage == REQUEST) {
deltas = wfTaskUtil.retrieveDeltasToProcess(wfTask.getTask());
} else {
deltas = wfTaskUtil.retrieveResultingDeltas(wfTask.getTask());
}
} catch (SchemaException e) {
throw new SystemException("Couldn't retrieve delta(s) from task " + wfTask.getTask(), e);
}
if (deltas != null) {
List<ObjectDelta<?>> deltaList = deltas.getDeltaList();
for (ObjectDelta delta : deltaList) {
auditEventRecord.addDelta(new ObjectDeltaOperation(delta));
}
}
return auditEventRecord;
}
use of com.evolveum.midpoint.audit.api.AuditEventRecord in project midpoint by Evolveum.
the class BaseAuditHelper method prepareWorkItemAuditReportCommon.
public AuditEventRecord prepareWorkItemAuditReportCommon(WorkItemType workItem, WfTask wfTask, AuditEventStage stage, OperationResult result) throws WorkflowException {
AuditEventRecord record = new AuditEventRecord();
record.setEventType(AuditEventType.WORK_ITEM);
record.setEventStage(stage);
ObjectReferenceType objectRef = resolveIfNeeded(WfContextUtil.getObjectRef(workItem), result);
record.setTarget(objectRef.asReferenceValue());
record.setOutcome(OperationResultStatus.SUCCESS);
record.setParameter(wfTask.getCompleteStageInfo());
record.addReferenceValueIgnoreNull(WorkflowConstants.AUDIT_OBJECT, objectRef);
record.addReferenceValueIgnoreNull(WorkflowConstants.AUDIT_TARGET, resolveIfNeeded(WfContextUtil.getTargetRef(workItem), result));
record.addReferenceValueIgnoreNull(WorkflowConstants.AUDIT_ORIGINAL_ASSIGNEE, resolveIfNeeded(workItem.getOriginalAssigneeRef(), result));
record.addReferenceValues(WorkflowConstants.AUDIT_CURRENT_ASSIGNEE, resolveIfNeeded(workItem.getAssigneeRef(), result));
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_STAGE_NUMBER, workItem.getStageNumber());
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_STAGE_COUNT, WfContextUtil.getStageCount(workItem));
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_STAGE_NAME, WfContextUtil.getStageName(workItem));
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_STAGE_DISPLAY_NAME, WfContextUtil.getStageDisplayName(workItem));
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_ESCALATION_LEVEL_NUMBER, WfContextUtil.getEscalationLevelNumber(workItem));
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_ESCALATION_LEVEL_NAME, WfContextUtil.getEscalationLevelName(workItem));
record.addPropertyValueIgnoreNull(WorkflowConstants.AUDIT_ESCALATION_LEVEL_DISPLAY_NAME, WfContextUtil.getEscalationLevelDisplayName(workItem));
record.addPropertyValue(WorkflowConstants.AUDIT_WORK_ITEM_ID, workItem.getExternalId());
record.addPropertyValue(WorkflowConstants.AUDIT_PROCESS_INSTANCE_ID, WfContextUtil.getProcessInstanceId(workItem));
return record;
}
use of com.evolveum.midpoint.audit.api.AuditEventRecord in project midpoint by Evolveum.
the class DummyAuditService method assertExecutionMessage.
public void assertExecutionMessage(int index) {
List<AuditEventRecord> executionRecords = getExecutionRecords();
AuditEventRecord executionRecord = executionRecords.get(index);
assert !StringUtils.isEmpty(executionRecord.getMessage()) : "Expected execution message in audit record but there was none; in " + executionRecord;
}
use of com.evolveum.midpoint.audit.api.AuditEventRecord in project midpoint by Evolveum.
the class DummyAuditService method getExecutionRecord.
public AuditEventRecord getExecutionRecord(int index) {
assertSingleBatch();
AuditEventRecord executionRecord = records.get(index + 1);
assert executionRecord != null : "The " + index + "th audit execution record is null";
assert executionRecord.getEventStage() == AuditEventStage.EXECUTION : "The " + index + "th audit execution record is not execution, it is " + executionRecord;
return executionRecord;
}
use of com.evolveum.midpoint.audit.api.AuditEventRecord in project midpoint by Evolveum.
the class DummyAuditService method assertExecutionOutcome.
public void assertExecutionOutcome(int index, OperationResultStatus expectedStatus) {
List<AuditEventRecord> executionRecords = getExecutionRecords();
AuditEventRecord executionRecord = executionRecords.get(index);
assert executionRecord.getOutcome() == expectedStatus : "Expected execution outcome " + expectedStatus + " in audit execution record (" + index + ") but it was " + executionRecord.getOutcome();
}
Aggregations