All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ca.uhn.fhir.mdm.provider.MdmProviderDstu3Plus Maven / Gradle / Ivy

/*-
 * #%L
 * HAPI FHIR - Master Data Management
 * %%
 * Copyright (C) 2014 - 2024 Smile CDR, Inc.
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */
package ca.uhn.fhir.mdm.provider;

import ca.uhn.fhir.context.FhirContext;
import ca.uhn.fhir.i18n.Msg;
import ca.uhn.fhir.interceptor.api.HookParams;
import ca.uhn.fhir.interceptor.api.IInterceptorBroadcaster;
import ca.uhn.fhir.interceptor.api.Pointcut;
import ca.uhn.fhir.mdm.api.IMdmControllerSvc;
import ca.uhn.fhir.mdm.api.IMdmSettings;
import ca.uhn.fhir.mdm.api.IMdmSubmitSvc;
import ca.uhn.fhir.mdm.api.MdmConstants;
import ca.uhn.fhir.mdm.api.paging.MdmPageRequest;
import ca.uhn.fhir.mdm.api.params.MdmQuerySearchParameters;
import ca.uhn.fhir.mdm.model.MdmCreateOrUpdateParams;
import ca.uhn.fhir.mdm.model.MdmMergeGoldenResourcesParams;
import ca.uhn.fhir.mdm.model.MdmTransactionContext;
import ca.uhn.fhir.mdm.model.MdmUnduplicateGoldenResourceParams;
import ca.uhn.fhir.mdm.model.mdmevents.MdmLinkJson;
import ca.uhn.fhir.mdm.model.mdmevents.MdmSubmitEvent;
import ca.uhn.fhir.model.api.annotation.Description;
import ca.uhn.fhir.rest.annotation.IdParam;
import ca.uhn.fhir.rest.annotation.Operation;
import ca.uhn.fhir.rest.annotation.OperationParam;
import ca.uhn.fhir.rest.api.Constants;
import ca.uhn.fhir.rest.api.server.RequestDetails;
import ca.uhn.fhir.rest.server.exceptions.InvalidRequestException;
import ca.uhn.fhir.rest.server.provider.ProviderConstants;
import ca.uhn.fhir.rest.server.servlet.ServletRequestDetails;
import ca.uhn.fhir.util.ParametersUtil;
import jakarta.annotation.Nonnull;
import org.apache.commons.lang3.StringUtils;
import org.hl7.fhir.instance.model.api.IAnyResource;
import org.hl7.fhir.instance.model.api.IBaseBundle;
import org.hl7.fhir.instance.model.api.IBaseParameters;
import org.hl7.fhir.instance.model.api.IBaseResource;
import org.hl7.fhir.instance.model.api.IIdType;
import org.hl7.fhir.instance.model.api.IPrimitiveType;
import org.slf4j.Logger;
import org.springframework.data.domain.Page;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.stream.Collectors;

import static ca.uhn.fhir.rest.api.Constants.PARAM_OFFSET;
import static org.apache.commons.lang3.ObjectUtils.isNotEmpty;
import static org.apache.commons.lang3.StringUtils.isNotBlank;
import static org.slf4j.LoggerFactory.getLogger;

public class MdmProviderDstu3Plus extends BaseMdmProvider {
	private static final Logger ourLog = getLogger(MdmProviderDstu3Plus.class);

	private static final String PATIENT_RESOURCE = "Patient";
	private static final String PRACTITIONER_RESOURCE = "Practitioner";

	private final IMdmSubmitSvc myMdmSubmitSvc;
	private final IMdmSettings myMdmSettings;
	private final MdmControllerHelper myMdmControllerHelper;

	private final IInterceptorBroadcaster myInterceptorBroadcaster;

	public static final int DEFAULT_PAGE_SIZE = 20;
	public static final int MAX_PAGE_SIZE = 100;

	/**
	 * Constructor
	 * 

* Note that this is not a spring bean. Any necessary injections should * happen in the constructor */ public MdmProviderDstu3Plus( FhirContext theFhirContext, IMdmControllerSvc theMdmControllerSvc, MdmControllerHelper theMdmHelper, IMdmSubmitSvc theMdmSubmitSvc, IInterceptorBroadcaster theIInterceptorBroadcaster, IMdmSettings theIMdmSettings) { super(theFhirContext, theMdmControllerSvc); myMdmControllerHelper = theMdmHelper; myMdmSubmitSvc = theMdmSubmitSvc; myInterceptorBroadcaster = theIInterceptorBroadcaster; myMdmSettings = theIMdmSettings; } /** * Searches for matches for the provided patient resource * @param thePatient - the patient resource * @param theRequestDetails - the request details * @return - any matches to the provided patient resource */ @Operation(name = ProviderConstants.EMPI_MATCH, typeName = "Patient") public IBaseBundle match( @OperationParam(name = ProviderConstants.MDM_MATCH_RESOURCE, min = 1, max = 1, typeName = "Patient") IAnyResource thePatient, RequestDetails theRequestDetails) { if (thePatient == null) { throw new InvalidRequestException(Msg.code(1498) + "resource may not be null"); } return myMdmControllerHelper.getMatchesAndPossibleMatchesForResource(thePatient, "Patient", theRequestDetails); } /** * Searches for matches for hte provided resource. * * @param theResource - the resource to match on * @param theResourceType - the resource type * @param theRequestDetails - the request details * @return - any matches to the provided resource */ @Operation(name = ProviderConstants.MDM_MATCH) public IBaseBundle serverMatch( @OperationParam(name = ProviderConstants.MDM_MATCH_RESOURCE, min = 1, max = 1) IAnyResource theResource, @OperationParam(name = ProviderConstants.MDM_RESOURCE_TYPE, min = 1, max = 1, typeName = "string") IPrimitiveType theResourceType, RequestDetails theRequestDetails) { if (theResource == null) { throw new InvalidRequestException(Msg.code(1499) + "resource may not be null"); } return myMdmControllerHelper.getMatchesAndPossibleMatchesForResource( theResource, theResourceType.getValueAsString(), theRequestDetails); } @Operation(name = ProviderConstants.MDM_MERGE_GOLDEN_RESOURCES) public IBaseResource mergeGoldenResources( @OperationParam( name = ProviderConstants.MDM_MERGE_GR_FROM_GOLDEN_RESOURCE_ID, min = 1, max = 1, typeName = "string") IPrimitiveType theFromGoldenResourceId, @OperationParam( name = ProviderConstants.MDM_MERGE_GR_TO_GOLDEN_RESOURCE_ID, min = 1, max = 1, typeName = "string") IPrimitiveType theToGoldenResourceId, @OperationParam(name = ProviderConstants.MDM_MERGE_RESOURCE, max = 1) IAnyResource theMergedResource, RequestDetails theRequestDetails) { validateMergeParameters(theFromGoldenResourceId, theToGoldenResourceId); MdmTransactionContext.OperationType operationType = (theMergedResource == null) ? MdmTransactionContext.OperationType.MERGE_GOLDEN_RESOURCES : MdmTransactionContext.OperationType.MANUAL_MERGE_GOLDEN_RESOURCES; MdmTransactionContext txContext = createMdmContext( theRequestDetails, operationType, getResourceType(ProviderConstants.MDM_MERGE_GR_FROM_GOLDEN_RESOURCE_ID, theFromGoldenResourceId)); MdmMergeGoldenResourcesParams params = new MdmMergeGoldenResourcesParams(); params.setFromGoldenResourceId(theFromGoldenResourceId.getValueAsString()); params.setToGoldenResourceId(theToGoldenResourceId.getValueAsString()); params.setManuallyMergedResource(theMergedResource); params.setMdmTransactionContext(txContext); params.setRequestDetails(theRequestDetails); return myMdmControllerSvc.mergeGoldenResources(params); } @Operation(name = ProviderConstants.MDM_UPDATE_LINK) public IBaseResource updateLink( @OperationParam(name = ProviderConstants.MDM_UPDATE_LINK_GOLDEN_RESOURCE_ID, min = 1, max = 1) IPrimitiveType theGoldenResourceId, @OperationParam(name = ProviderConstants.MDM_UPDATE_LINK_RESOURCE_ID, min = 1, max = 1) IPrimitiveType theResourceId, @OperationParam(name = ProviderConstants.MDM_UPDATE_LINK_MATCH_RESULT, min = 1, max = 1) IPrimitiveType theMatchResult, ServletRequestDetails theRequestDetails) { validateUpdateLinkParameters(theGoldenResourceId, theResourceId, theMatchResult); MdmCreateOrUpdateParams updateLinkParams = new MdmCreateOrUpdateParams(); updateLinkParams.setGoldenResourceId(theGoldenResourceId.getValueAsString()); updateLinkParams.setResourceId(theResourceId.getValue()); updateLinkParams.setMatchResult(MdmControllerUtil.extractMatchResultOrNull(theMatchResult.getValue())); updateLinkParams.setMdmContext(createMdmContext( theRequestDetails, MdmTransactionContext.OperationType.UPDATE_LINK, getResourceType(ProviderConstants.MDM_UPDATE_LINK_GOLDEN_RESOURCE_ID, theGoldenResourceId))); updateLinkParams.setRequestDetails(theRequestDetails); return myMdmControllerSvc.updateLink(updateLinkParams); } @Operation(name = ProviderConstants.MDM_CREATE_LINK) public IBaseResource createLink( @OperationParam(name = ProviderConstants.MDM_CREATE_LINK_GOLDEN_RESOURCE_ID, min = 1, max = 1) IPrimitiveType theGoldenResourceId, @OperationParam(name = ProviderConstants.MDM_CREATE_LINK_RESOURCE_ID, min = 1, max = 1) IPrimitiveType theResourceId, @OperationParam(name = ProviderConstants.MDM_CREATE_LINK_MATCH_RESULT, min = 0, max = 1) IPrimitiveType theMatchResult, ServletRequestDetails theRequestDetails) { validateCreateLinkParameters(theGoldenResourceId, theResourceId, theMatchResult); MdmCreateOrUpdateParams params = new MdmCreateOrUpdateParams(); params.setGoldenResourceId(theGoldenResourceId.getValueAsString()); params.setResourceId(theResourceId.getValue()); params.setMatchResult(MdmControllerUtil.extractMatchResultOrNull(extractStringOrNull(theMatchResult))); params.setRequestDetails(theRequestDetails); params.setMdmContext(createMdmContext( theRequestDetails, MdmTransactionContext.OperationType.CREATE_LINK, getResourceType(ProviderConstants.MDM_CREATE_LINK_GOLDEN_RESOURCE_ID, theGoldenResourceId))); return myMdmControllerSvc.createLink(params); } @Operation( name = ProviderConstants.OPERATION_MDM_CLEAR, returnParameters = { @OperationParam(name = ProviderConstants.OPERATION_BATCH_RESPONSE_JOB_ID, typeName = "decimal") }) public IBaseParameters clearMdmLinks( @OperationParam( name = ProviderConstants.OPERATION_MDM_CLEAR_RESOURCE_NAME, min = 0, max = OperationParam.MAX_UNLIMITED, typeName = "string") List> theResourceNames, @OperationParam(name = ProviderConstants.OPERATION_MDM_BATCH_SIZE, typeName = "decimal", min = 0, max = 1) IPrimitiveType theBatchSize, ServletRequestDetails theRequestDetails) { List resourceNames = new ArrayList<>(); if (isNotEmpty(theResourceNames)) { resourceNames.addAll( theResourceNames.stream().map(IPrimitiveType::getValue).collect(Collectors.toList())); validateResourceNames(resourceNames); } else { resourceNames.addAll(myMdmSettings.getMdmRules().getMdmTypes()); } return myMdmControllerSvc.submitMdmClearJob(resourceNames, theBatchSize, theRequestDetails); } private void validateResourceNames(List theResourceNames) { for (String resourceName : theResourceNames) { if (!myMdmSettings.isSupportedMdmType(resourceName)) { throw new InvalidRequestException(Msg.code(1500) + ProviderConstants.OPERATION_MDM_CLEAR + " does not support resource type: " + resourceName); } } } // Is a set of the OR sufficient ot the contenxt she's investigating? @Operation(name = ProviderConstants.MDM_QUERY_LINKS, idempotent = true) public IBaseParameters queryLinks( @OperationParam( name = ProviderConstants.MDM_QUERY_LINKS_GOLDEN_RESOURCE_ID, min = 0, max = 1, typeName = "string") IPrimitiveType theGoldenResourceId, @OperationParam(name = ProviderConstants.MDM_QUERY_LINKS_RESOURCE_ID, min = 0, max = 1, typeName = "string") IPrimitiveType theResourceId, @OperationParam( name = ProviderConstants.MDM_QUERY_LINKS_MATCH_RESULT, min = 0, max = 1, typeName = "string") IPrimitiveType theMatchResult, @OperationParam(name = ProviderConstants.MDM_QUERY_LINKS_LINK_SOURCE, min = 0, max = 1, typeName = "string") IPrimitiveType theLinkSource, @Description( value = "Results from this method are returned across multiple pages. This parameter controls the offset when fetching a page.") @OperationParam(name = PARAM_OFFSET, min = 0, max = 1, typeName = "integer") IPrimitiveType theOffset, @Description( value = "Results from this method are returned across multiple pages. This parameter controls the size of those pages.") @OperationParam(name = Constants.PARAM_COUNT, min = 0, max = 1, typeName = "integer") IPrimitiveType theCount, @OperationParam(name = Constants.PARAM_SORT, min = 0, max = 1, typeName = "string") IPrimitiveType theSort, ServletRequestDetails theRequestDetails, @OperationParam(name = ProviderConstants.MDM_RESOURCE_TYPE, min = 0, max = 1, typeName = "string") IPrimitiveType theResourceType) { MdmPageRequest mdmPageRequest = new MdmPageRequest(theOffset, theCount, DEFAULT_PAGE_SIZE, MAX_PAGE_SIZE); MdmTransactionContext mdmContext = createMdmContext( theRequestDetails, MdmTransactionContext.OperationType.QUERY_LINKS, getResourceType( ProviderConstants.MDM_QUERY_LINKS_GOLDEN_RESOURCE_ID, theGoldenResourceId, theResourceType)); MdmQuerySearchParameters mdmQuerySearchParameters = new MdmQuerySearchParameters(mdmPageRequest) .setGoldenResourceId(extractStringOrNull(theGoldenResourceId)) .setSourceId(extractStringOrNull(theResourceId)) .setLinkSource(extractStringOrNull(theLinkSource)) .setMatchResult(extractStringOrNull(theMatchResult)) .setResourceType(extractStringOrNull(theResourceType)) .setSort(extractStringOrNull(theSort)); Page mdmLinkJson = myMdmControllerSvc.queryLinks(mdmQuerySearchParameters, mdmContext, theRequestDetails); return parametersFromMdmLinks(mdmLinkJson, true, theRequestDetails, mdmPageRequest); } @Operation(name = ProviderConstants.MDM_DUPLICATE_GOLDEN_RESOURCES, idempotent = true) public IBaseParameters getDuplicateGoldenResources( @Description( formalDefinition = "Results from this method are returned across multiple pages. This parameter controls the offset when fetching a page.") @OperationParam(name = PARAM_OFFSET, min = 0, max = 1, typeName = "integer") IPrimitiveType theOffset, @Description( formalDefinition = "Results from this method are returned across multiple pages. This parameter controls the size of those pages.") @OperationParam(name = Constants.PARAM_COUNT, min = 0, max = 1, typeName = "integer") IPrimitiveType theCount, ServletRequestDetails theRequestDetails, @Description(formalDefinition = "This parameter controls the returned resource type.") @OperationParam(name = ProviderConstants.MDM_RESOURCE_TYPE, min = 0, max = 1, typeName = "string") IPrimitiveType theResourceType) { MdmPageRequest mdmPageRequest = new MdmPageRequest(theOffset, theCount, DEFAULT_PAGE_SIZE, MAX_PAGE_SIZE); Page possibleDuplicates = myMdmControllerSvc.getDuplicateGoldenResources( createMdmContext( theRequestDetails, MdmTransactionContext.OperationType.DUPLICATE_GOLDEN_RESOURCES, null), mdmPageRequest, theRequestDetails, extractStringOrNull(theResourceType)); return parametersFromMdmLinks(possibleDuplicates, false, theRequestDetails, mdmPageRequest); } @Operation(name = ProviderConstants.MDM_NOT_DUPLICATE) public IBaseParameters notDuplicate( @OperationParam( name = ProviderConstants.MDM_QUERY_LINKS_GOLDEN_RESOURCE_ID, min = 1, max = 1, typeName = "string") IPrimitiveType theGoldenResourceId, @OperationParam(name = ProviderConstants.MDM_QUERY_LINKS_RESOURCE_ID, min = 1, max = 1, typeName = "string") IPrimitiveType theResourceId, ServletRequestDetails theRequestDetails) { validateNotDuplicateParameters(theGoldenResourceId, theResourceId); MdmUnduplicateGoldenResourceParams params = new MdmUnduplicateGoldenResourceParams(); params.setRequestDetails(theRequestDetails); params.setGoldenResourceId(theGoldenResourceId.getValueAsString()); params.setTargetGoldenResourceId(theResourceId.getValueAsString()); params.setMdmContext(createMdmContext( theRequestDetails, MdmTransactionContext.OperationType.NOT_DUPLICATE, getResourceType(ProviderConstants.MDM_QUERY_LINKS_GOLDEN_RESOURCE_ID, theGoldenResourceId))); myMdmControllerSvc.unduplicateGoldenResource(params); IBaseParameters retval = ParametersUtil.newInstance(myFhirContext); ParametersUtil.addParameterToParametersBoolean(myFhirContext, retval, "success", true); return retval; } @Operation( name = ProviderConstants.OPERATION_MDM_SUBMIT, idempotent = false, returnParameters = { @OperationParam(name = ProviderConstants.OPERATION_MDM_SUBMIT_OUT_PARAM_SUBMITTED, typeName = "integer") }) public IBaseParameters mdmBatchOnAllSourceResources( @OperationParam(name = ProviderConstants.MDM_BATCH_RUN_RESOURCE_TYPE, min = 0, max = 1, typeName = "string") IPrimitiveType theResourceType, @OperationParam(name = ProviderConstants.MDM_BATCH_RUN_CRITERIA, min = 0, max = 1, typeName = "string") IPrimitiveType theCriteria, @OperationParam(name = ProviderConstants.OPERATION_MDM_BATCH_SIZE, typeName = "decimal", min = 0, max = 1) IPrimitiveType theBatchSize, ServletRequestDetails theRequestDetails) { String criteria = convertStringTypeToString(theCriteria); String resourceType = convertStringTypeToString(theResourceType); long submittedCount; IBaseParameters retval; if (theRequestDetails.isPreferRespondAsync()) { List urls = buildUrlsForJob(criteria, resourceType); retval = myMdmControllerSvc.submitMdmSubmitJob(urls, theBatchSize, theRequestDetails); } else { submittedCount = synchronousMdmSubmit(resourceType, null, criteria, theRequestDetails); retval = buildMdmOutParametersWithCount(submittedCount); } return retval; } @Nonnull private List buildUrlsForJob(String criteria, String resourceType) { List urls = new ArrayList<>(); if (isNotBlank(resourceType)) { String theUrl = resourceType + "?" + criteria; urls.add(theUrl); } else { myMdmSettings.getMdmRules().getMdmTypes().stream() .map(type -> type + "?" + criteria) .forEach(urls::add); } return urls; } private String convertStringTypeToString(IPrimitiveType theCriteria) { return theCriteria == null ? "" : theCriteria.getValueAsString(); } @Operation( name = ProviderConstants.OPERATION_MDM_SUBMIT, idempotent = false, typeName = "Patient", returnParameters = { @OperationParam(name = ProviderConstants.OPERATION_BATCH_RESPONSE_JOB_ID, typeName = "integer") }) public IBaseParameters mdmBatchPatientInstance(@IdParam IIdType theIdParam, RequestDetails theRequest) { long submittedCount = synchronousMdmSubmit(null, theIdParam, null, theRequest); return buildMdmOutParametersWithCount(submittedCount); } @Operation( name = ProviderConstants.OPERATION_MDM_SUBMIT, idempotent = false, typeName = "Patient", returnParameters = { @OperationParam(name = ProviderConstants.OPERATION_BATCH_RESPONSE_JOB_ID, typeName = "integer") }) public IBaseParameters mdmBatchPatientType( @OperationParam(name = ProviderConstants.MDM_BATCH_RUN_CRITERIA, typeName = "string") IPrimitiveType theCriteria, @OperationParam(name = ProviderConstants.OPERATION_MDM_BATCH_SIZE, typeName = "decimal", min = 0, max = 1) IPrimitiveType theBatchSize, ServletRequestDetails theRequest) { if (theRequest.isPreferRespondAsync()) { String theUrl = PATIENT_RESOURCE + "?"; return myMdmControllerSvc.submitMdmSubmitJob(Collections.singletonList(theUrl), theBatchSize, theRequest); } else { String criteria = convertStringTypeToString(theCriteria); long submittedCount = synchronousMdmSubmit(PATIENT_RESOURCE, null, criteria, theRequest); return buildMdmOutParametersWithCount(submittedCount); } } @Operation( name = ProviderConstants.OPERATION_MDM_SUBMIT, idempotent = false, typeName = "Practitioner", returnParameters = { @OperationParam(name = ProviderConstants.OPERATION_BATCH_RESPONSE_JOB_ID, typeName = "integer") }) public IBaseParameters mdmBatchPractitionerInstance(@IdParam IIdType theIdParam, RequestDetails theRequest) { long submittedCount = synchronousMdmSubmit(null, theIdParam, null, theRequest); return buildMdmOutParametersWithCount(submittedCount); } @Operation( name = ProviderConstants.OPERATION_MDM_SUBMIT, idempotent = false, typeName = "Practitioner", returnParameters = { @OperationParam(name = ProviderConstants.OPERATION_BATCH_RESPONSE_JOB_ID, typeName = "integer") }) public IBaseParameters mdmBatchPractitionerType( @OperationParam(name = ProviderConstants.MDM_BATCH_RUN_CRITERIA, typeName = "string") IPrimitiveType theCriteria, @OperationParam(name = ProviderConstants.OPERATION_MDM_BATCH_SIZE, typeName = "decimal", min = 0, max = 1) IPrimitiveType theBatchSize, ServletRequestDetails theRequest) { if (theRequest.isPreferRespondAsync()) { String theUrl = PRACTITIONER_RESOURCE + "?"; return myMdmControllerSvc.submitMdmSubmitJob(Collections.singletonList(theUrl), theBatchSize, theRequest); } else { String criteria = convertStringTypeToString(theCriteria); long submittedCount = synchronousMdmSubmit(PRACTITIONER_RESOURCE, null, criteria, theRequest); return buildMdmOutParametersWithCount(submittedCount); } } /** * Helper function to build the out-parameters for all batch MDM operations. */ public IBaseParameters buildMdmOutParametersWithCount(long theCount) { IBaseParameters retval = ParametersUtil.newInstance(myFhirContext); ParametersUtil.addParameterToParametersLong( myFhirContext, retval, ProviderConstants.OPERATION_MDM_SUBMIT_OUT_PARAM_SUBMITTED, theCount); return retval; } private String getResourceType(String theParamName, IPrimitiveType theResourceId) { if (theResourceId != null) { return getResourceType(theParamName, theResourceId.getValueAsString()); } else { return MdmConstants.UNKNOWN_MDM_TYPES; } } private String getResourceType( String theParamName, IPrimitiveType theResourceId, IPrimitiveType theResourceType) { return theResourceType != null ? theResourceType.getValueAsString() : getResourceType(theParamName, theResourceId); } private String getResourceType(String theParamName, String theResourceId) { if (StringUtils.isEmpty(theResourceId)) { return MdmConstants.UNKNOWN_MDM_TYPES; } IIdType idType = MdmControllerUtil.getGoldenIdDtOrThrowException(theParamName, theResourceId); return idType.getResourceType(); } private long synchronousMdmSubmit( String theResourceType, IIdType theIdType, String theCriteria, RequestDetails theRequestDetails) { long submittedCount = -1; List urls = new ArrayList<>(); if (theIdType != null) { submittedCount = mdmSubmitWithId(theIdType, theRequestDetails, urls); } else if (isNotBlank(theResourceType)) { submittedCount = submitResourceTypeWithCriteria(theResourceType, theCriteria, theRequestDetails, urls); } else { submittedCount = submitAll(theCriteria, theRequestDetails, urls); } if (myInterceptorBroadcaster.hasHooks(Pointcut.MDM_SUBMIT)) { // MDM_SUBMIT synchronous submit MdmSubmitEvent submitEvent = new MdmSubmitEvent(); submitEvent.setBatchJob(false); submitEvent.setUrls(urls); HookParams hookParams = new HookParams(); hookParams.add(RequestDetails.class, theRequestDetails); hookParams.add(MdmSubmitEvent.class, submitEvent); myInterceptorBroadcaster.callHooks(Pointcut.MDM_SUBMIT, hookParams); } return submittedCount; } private long mdmSubmitWithId(IIdType theIdType, RequestDetails theRequestDetails, List theUrls) { theUrls.add(theIdType.getValue()); return myMdmSubmitSvc.submitSourceResourceToMdm(theIdType, theRequestDetails); } private long submitResourceTypeWithCriteria( String theResourceType, String theCriteria, RequestDetails theRequestDetails, List theUrls) { String url = theResourceType; if (isNotEmpty(theCriteria)) { url += "?" + theCriteria; } theUrls.add(url); return myMdmSubmitSvc.submitSourceResourceTypeToMdm(theResourceType, theCriteria, theRequestDetails); } private long submitAll(String theCriteria, RequestDetails theRequestDetails, List theUrls) { // submitAllSourceTypes only runs through // valid MDM source types List resourceTypes = myMdmSettings.getMdmRules().getMdmTypes(); for (String resourceType : resourceTypes) { String url = resourceType + (isNotEmpty(theCriteria) ? "?" + theCriteria : ""); theUrls.add(url); } return myMdmSubmitSvc.submitAllSourceTypesToMdm(theCriteria, theRequestDetails); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy