001/*-
002 * #%L
003 * HAPI FHIR - Master Data Management
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 *      http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.mdm.util;
021
022import ca.uhn.fhir.context.FhirContext;
023import ca.uhn.fhir.mdm.api.IMdmSettings;
024import ca.uhn.fhir.mdm.api.MdmConstants;
025import ca.uhn.fhir.mdm.api.MdmMatchResultEnum;
026import ca.uhn.fhir.rest.server.provider.ProviderConstants;
027import org.hl7.fhir.instance.model.api.IAnyResource;
028import org.springframework.beans.factory.annotation.Autowired;
029import org.springframework.stereotype.Service;
030
031@Service
032public class MessageHelper {
033
034        @Autowired
035        private final IMdmSettings myMdmSettings;
036
037        @Autowired
038        private final FhirContext myFhirContext;
039
040        public MessageHelper(IMdmSettings theMdmSettings, FhirContext theFhirContext) {
041                myMdmSettings = theMdmSettings;
042                myFhirContext = theFhirContext;
043        }
044
045        public String getMessageForUnmanagedResource() {
046                return String.format(
047                                "Only MDM managed resources can be merged. MDM managed resources must have the %s tag.",
048                                MdmConstants.CODE_HAPI_MDM_MANAGED);
049        }
050
051        public String getMessageForUnsupportedResource(String theName, IAnyResource theResource) {
052                return getMessageForUnsupportedResource(theName, myFhirContext.getResourceType(theResource));
053        }
054
055        public String getMessageForUnsupportedResource(String theName, String theResourceType) {
056                return String.format(
057                                "Only %s resources can be merged. The %s points to a %s",
058                                myMdmSettings.getSupportedMdmTypes(), theName, theResourceType);
059        }
060
061        public String getMessageForUnsupportedMatchResult() {
062                return "Match Result may only be set to " + MdmMatchResultEnum.NO_MATCH + " or " + MdmMatchResultEnum.MATCH;
063        }
064
065        public String getMessageForUnsupportedFirstArgumentTypeInUpdate(String goldenRecordType) {
066                return "First argument to " + ProviderConstants.MDM_UPDATE_LINK + " must be a "
067                                + myMdmSettings.getSupportedMdmTypes() + ".  Was " + goldenRecordType;
068        }
069
070        public String getMessageForUnsupportedSecondArgumentTypeInUpdate(String theGoldenRecordType) {
071                return "First argument to " + ProviderConstants.MDM_UPDATE_LINK + " must be a "
072                                + myMdmSettings.getSupportedMdmTypes() + ".  Was " + theGoldenRecordType;
073        }
074
075        public String getMessageForArgumentTypeMismatchInUpdate(String theGoldenRecordType, String theSourceResourceType) {
076                return "Arguments to " + ProviderConstants.MDM_UPDATE_LINK + " must be of the same type. Were "
077                                + theGoldenRecordType + " and " + theSourceResourceType;
078        }
079
080        public String getMessageForUnsupportedSourceResource() {
081                return "The source resource is marked with the " + MdmConstants.CODE_NO_MDM_MANAGED
082                                + " tag which means it may not be MDM linked.";
083        }
084
085        public String getMessageForNoLink(IAnyResource theGoldenRecord, IAnyResource theSourceResource) {
086                return getMessageForNoLink(
087                                theGoldenRecord.getIdElement().toVersionless().toString(),
088                                theSourceResource.getIdElement().toVersionless().toString());
089        }
090
091        public String getMessageForNoLink(String theGoldenRecord, String theSourceResource) {
092                return "No link exists between " + theGoldenRecord + " and " + theSourceResource;
093        }
094
095        public String getMessageForAlreadyAcceptedLink(IAnyResource theGoldenRecord, IAnyResource theSourceResource) {
096                return getMessageForAlreadyAcceptedLink(
097                                theGoldenRecord.getIdElement().toVersionless().toString(),
098                                theSourceResource.getIdElement().toVersionless().toString());
099        }
100
101        public String getMessageForAlreadyAcceptedLink(String theGoldenId, String theSourceId) {
102                return "A match with a different golden resource (" + theGoldenId + ") exists for resource " + theSourceId;
103        }
104
105        public String getMessageForPresentLink(IAnyResource theGoldenRecord, IAnyResource theSourceResource) {
106                return getMessageForPresentLink(
107                                theGoldenRecord.getIdElement().toVersionless().toString(),
108                                theSourceResource.getIdElement().toVersionless().toString());
109        }
110
111        public String getMessageForPresentLink(String theGoldenRecord, String theSourceResource) {
112                return "Link already exists between " + theGoldenRecord + " and " + theSourceResource
113                                + ". Use $mdm-update-link instead.";
114        }
115
116        public String getMessageForMultipleGoldenRecords(IAnyResource theSourceResource) {
117                return getMessageForMultipleGoldenRecords(
118                                theSourceResource.getIdElement().toVersionless().toString());
119        }
120
121        public String getMessageForMultipleGoldenRecords(String theSourceResource) {
122                return theSourceResource + " already has matched golden resource. Use $mdm-query-links to see more details.";
123        }
124
125        public String getMessageForFailedGoldenResourceLoad(String theParamName, String theGoldenResourceId) {
126                return theGoldenResourceId + " used as parameter [" + theParamName
127                                + "] could not be loaded as a golden resource, as it appears to be lacking the golden resource meta tags.";
128        }
129
130        public String getMessageForMismatchPartition(IAnyResource theGoldenRecord, IAnyResource theSourceResource) {
131                return getMessageForMismatchPartition(
132                                theGoldenRecord.getIdElement().toVersionless().toString(),
133                                theSourceResource.getIdElement().toVersionless().toString());
134        }
135
136        public String getMessageForMismatchPartition(String theGoldenRecord, String theSourceResource) {
137                return theGoldenRecord + " and " + theSourceResource
138                                + " are stored in different partitions. This operation is only available for resources on the same partition.";
139        }
140}