001/*
002 * #%L
003 * HAPI FHIR - Core Library
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.model.base.composite;
021
022import ca.uhn.fhir.context.FhirContext;
023import ca.uhn.fhir.i18n.Msg;
024import ca.uhn.fhir.model.api.BaseIdentifiableElement;
025import ca.uhn.fhir.model.api.ICompositeDatatype;
026import ca.uhn.fhir.model.api.IQueryParameterType;
027import ca.uhn.fhir.model.primitive.StringDt;
028import ca.uhn.fhir.model.primitive.UriDt;
029import ca.uhn.fhir.rest.param.ParameterUtil;
030import ca.uhn.fhir.rest.param.StringParam;
031import org.apache.commons.lang3.StringUtils;
032
033public abstract class BaseIdentifierDt extends BaseIdentifiableElement
034                implements ICompositeDatatype, IQueryParameterType {
035
036        private static final long serialVersionUID = 4400972469749953077L;
037
038        @Override
039        public String getQueryParameterQualifier() {
040                return null;
041        }
042
043        /**
044         * Gets the value(s) for <b>system</b> (The namespace for the identifier). creating it if it does not exist. Will not return <code>null</code>.
045         *
046         * <p>
047         * <b>Definition:</b> Establishes the namespace in which set of possible id values is unique.
048         * </p>
049         */
050        public abstract UriDt getSystemElement();
051
052        /**
053         * Gets the value(s) for <b>value</b> (The value that is unique). creating it if it does not exist. Will not return <code>null</code>.
054         *
055         * <p>
056         * <b>Definition:</b> The portion of the identifier typically displayed to the user and which is unique within the context of the system.
057         * </p>
058         */
059        public abstract StringDt getValueElement();
060
061        /**
062         * {@inheritDoc}
063         */
064        @Override
065        public String getValueAsQueryToken(FhirContext theContext) {
066                UriDt system = getSystemElement();
067                StringDt value = getValueElement();
068                if (system.getValueAsString() != null) {
069                        return ParameterUtil.escape(StringUtils.defaultString(system.getValueAsString()))
070                                        + '|'
071                                        + ParameterUtil.escape(value.getValueAsString());
072                }
073                return ParameterUtil.escape(value.getValueAsString());
074        }
075
076        /**
077         * Returns true if <code>this</code> identifier has the same {@link #getValueElement() value} and
078         * {@link #getSystemElement() system} (as compared by simple equals comparison). Does not compare other values (e.g.
079         * getUse()) or any extensions.
080         */
081        public boolean matchesSystemAndValue(BaseIdentifierDt theIdentifier) {
082                if (theIdentifier == null) {
083                        return false;
084                }
085                return getValueElement().equals(theIdentifier.getValueElement())
086                                && getSystemElement().equals(theIdentifier.getSystemElement());
087        }
088
089        /**
090         * Sets the value for <b>system</b> (The namespace for the identifier)
091         *
092         * <p>
093         * <b>Definition:</b> Establishes the namespace in which set of possible id values is unique.
094         * </p>
095         */
096        public abstract BaseIdentifierDt setSystem(String theUri);
097
098        /**
099         * Sets the value for <b>value</b> (The value that is unique)
100         *
101         * <p>
102         * <b>Definition:</b> The portion of the identifier typically displayed to the user and which is unique within the context of the system.
103         * </p>
104         */
105        public abstract BaseIdentifierDt setValue(String theString);
106
107        /**
108         * {@inheritDoc}
109         */
110        @Override
111        public void setValueAsQueryToken(
112                        FhirContext theContext, String theParamName, String theQualifier, String theParameter) {
113                int barIndex = ParameterUtil.nonEscapedIndexOf(theParameter, '|');
114                if (barIndex != -1) {
115                        setSystem(theParameter.substring(0, barIndex));
116                        setValue(ParameterUtil.unescape(theParameter.substring(barIndex + 1)));
117                } else {
118                        setValue(ParameterUtil.unescape(theParameter));
119                }
120        }
121
122        /**
123         * <b>Not supported!</b>
124         *
125         * @deprecated get/setMissing is not supported in StringDt. Use {@link StringParam} instead if you
126         * need this functionality
127         */
128        @Deprecated
129        @Override
130        public Boolean getMissing() {
131                return null;
132        }
133
134        /**
135         * <b>Not supported!</b>
136         *
137         * @deprecated get/setMissing is not supported in StringDt. Use {@link StringParam} instead if you
138         * need this functionality
139         */
140        @Deprecated
141        @Override
142        public IQueryParameterType setMissing(Boolean theMissing) {
143                throw new UnsupportedOperationException(
144                                Msg.code(1907)
145                                                + "get/setMissing is not supported in StringDt. Use {@link StringParam} instead if you need this functionality");
146        }
147}