@Override public GenericFhirAuditDataset createAuditDataset() { return new GenericFhirAuditDataset(isServerSide()); }
@Override public AuditMessage[] makeAuditMessage(AuditContext auditContext, GenericFhirAuditDataset auditDataset) { GenericFhirAuditMessageBuilder builder = new GenericFhirAuditMessageBuilder(auditContext, auditDataset) .addPatients(auditDataset); if (auditDataset.getAffectedResourceType() != null && auditDataset.getQueryString() != null) { builder.addQueryParticipantObject(auditDataset); } else if (auditDataset.getResourceId() != null && auditDataset.getResourceId().hasResourceType() && auditDataset.getResourceId().hasIdPart()) { builder.addResourceParticipantObject(auditDataset); } return builder.getMessages(); }
resourceType = RequestDetailProvider.getRequestDetails().getResourceName(); auditDataset.setAffectedResourceType(resourceType); operation = RequestDetailProvider.getRequestDetails().getRestOperationType(); auditDataset.setOperation(operation); addResourceData(auditDataset, (T) request); } else if (request instanceof IIdType) { auditDataset.setResourceId((IIdType) request); auditDataset.setQueryString(query); List<TokenParam> tokenParams = searchParameter.getPatientIdParam(); if (tokenParams != null) { auditDataset.getPatientIds().addAll( tokenParams.stream() .map(t -> t.getValueAsQueryToken(searchParameter.getFhirContext()))
private void addResourceData(GenericFhirAuditDataset auditDataset, T resource) { auditDataset.setResourceId(resource.getIdElement()); if (resource.getIdElement().hasResourceType()) { auditDataset.setAffectedResourceType(resource.getIdElement().getResourceType()); } patientIdExtractor.apply(resource).ifPresent(patient -> auditDataset.getPatientIds().add(patient.getResource() != null ? patient.getResource().getIdElement().toUnqualifiedVersionless().getValue() : patient.getReference())); List<? extends IBaseCoding> securityLabels = resource.getMeta().getSecurity(); if (!securityLabels.isEmpty()) { auditDataset.setSecurityLabel(securityLabels.get(0).getCode()); } } }
@Override public boolean enrichAuditDatasetFromResponse(GenericFhirAuditDataset auditDataset, Object response, AuditContext auditContext) { // Domain Resource in the request? Extract Patient ID and Sensitivity at this point if (response instanceof IDomainResource) { addResourceData(auditDataset, (T) response); } if (response instanceof MethodOutcome) { MethodOutcome methodOutcome = (MethodOutcome) response; if (methodOutcome.getCreated() != null && methodOutcome.getCreated()) { auditDataset.setEventOutcomeIndicator(EventOutcomeIndicator.Success); } if (methodOutcome.getOperationOutcome() != null) { super.enrichAuditDatasetFromResponse(auditDataset, methodOutcome.getOperationOutcome(), auditContext); } else { auditDataset.setEventOutcomeIndicator(EventOutcomeIndicator.Success); } if (methodOutcome.getResource() != null && methodOutcome.getResource() instanceof IDomainResource) { addResourceData(auditDataset, (T) methodOutcome.getResource()); } else if (methodOutcome.getId() != null) { auditDataset.setResourceId(methodOutcome.getId()); if (methodOutcome.getId().hasResourceType()) { auditDataset.setAffectedResourceType(methodOutcome.getId().getResourceType()); } } } return super.enrichAuditDatasetFromResponse(auditDataset, response, auditContext); }
resourceType = RequestDetailProvider.getRequestDetails().getResourceName(); auditDataset.setAffectedResourceType(resourceType); operation = RequestDetailProvider.getRequestDetails().getRestOperationType(); auditDataset.setOperation(operation); addResourceData(auditDataset, (T) request); } else if (request instanceof IIdType) { auditDataset.setResourceId((IIdType) request); auditDataset.setQueryString(query); List<TokenParam> tokenParams = searchParameter.getPatientIdParam(); if (tokenParams != null) { auditDataset.getPatientIds().addAll( tokenParams.stream() .map(t -> t.getValueAsQueryToken(searchParameter.getFhirContext()))
private void addResourceData(GenericFhirAuditDataset auditDataset, T resource) { auditDataset.setResourceId(resource.getIdElement()); if (resource.getIdElement().hasResourceType()) { auditDataset.setAffectedResourceType(resource.getIdElement().getResourceType()); } patientIdExtractor.apply(resource).ifPresent(patient -> auditDataset.getPatientIds().add(patient.getResource() != null ? patient.getResource().getIdElement().toUnqualifiedVersionless().getValue() : patient.getReference())); List<? extends IBaseCoding> securityLabels = resource.getMeta().getSecurity(); if (!securityLabels.isEmpty()) { auditDataset.setSecurityLabel(securityLabels.get(0).getCode()); } } }
@Override public boolean enrichAuditDatasetFromResponse(GenericFhirAuditDataset auditDataset, Object response, AuditContext auditContext) { // Domain Resource in the request? Extract Patient ID and Sensitivity at this point if (response instanceof IDomainResource) { addResourceData(auditDataset, (T) response); } if (response instanceof MethodOutcome) { MethodOutcome methodOutcome = (MethodOutcome) response; if (methodOutcome.getCreated() != null && methodOutcome.getCreated()) { auditDataset.setEventOutcomeIndicator(EventOutcomeIndicator.Success); } if (methodOutcome.getOperationOutcome() != null) { super.enrichAuditDatasetFromResponse(auditDataset, methodOutcome.getOperationOutcome(), auditContext); } else { auditDataset.setEventOutcomeIndicator(EventOutcomeIndicator.Success); } if (methodOutcome.getResource() != null && methodOutcome.getResource() instanceof IDomainResource) { addResourceData(auditDataset, (T) methodOutcome.getResource()); } else if (methodOutcome.getId() != null) { auditDataset.setResourceId(methodOutcome.getId()); if (methodOutcome.getId().hasResourceType()) { auditDataset.setAffectedResourceType(methodOutcome.getId().getResourceType()); } } } return super.enrichAuditDatasetFromResponse(auditDataset, response, auditContext); }
@Override public AuditMessage[] makeAuditMessage(AuditContext auditContext, GenericFhirAuditDataset auditDataset) { GenericFhirAuditMessageBuilder builder = new GenericFhirAuditMessageBuilder(auditContext, auditDataset) .addPatients(auditDataset); if (auditDataset.getAffectedResourceType() != null && auditDataset.getQueryString() != null) { builder.addQueryParticipantObject(auditDataset); } else if (auditDataset.getResourceId() != null && auditDataset.getResourceId().hasResourceType() && auditDataset.getResourceId().hasIdPart()) { builder.addResourceParticipantObject(auditDataset); } return builder.getMessages(); }
@Override public GenericFhirAuditDataset createAuditDataset() { return new GenericFhirAuditDataset(isServerSide()); }