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.rest.param; 021 022import ca.uhn.fhir.context.FhirContext; 023import ca.uhn.fhir.model.api.IQueryParameterType; 024import ca.uhn.fhir.model.primitive.StringDt; 025import ca.uhn.fhir.model.primitive.UriDt; 026import org.apache.commons.lang3.StringUtils; 027import org.apache.commons.lang3.builder.ToStringBuilder; 028import org.apache.commons.lang3.builder.ToStringStyle; 029 030import static org.apache.commons.lang3.StringUtils.defaultString; 031 032public class UriParam extends BaseParam implements IQueryParameterType { 033 034 private UriParamQualifierEnum myQualifier; 035 private String myValue; 036 037 /** 038 * Constructor 039 */ 040 public UriParam() { 041 super(); 042 } 043 044 public UriParam(String theValue) { 045 setValue(theValue); 046 } 047 048 @Override 049 String doGetQueryParameterQualifier() { 050 return myQualifier != null ? myQualifier.getValue() : null; 051 } 052 053 @Override 054 String doGetValueAsQueryToken(FhirContext theContext) { 055 return ParameterUtil.escape(myValue); 056 } 057 058 @Override 059 void doSetValueAsQueryToken(FhirContext theContext, String theParamName, String theQualifier, String theValue) { 060 myQualifier = UriParamQualifierEnum.forValue(theQualifier); 061 myValue = ParameterUtil.unescape(theValue); 062 } 063 064 /** 065 * Gets the qualifier for this param (may be <code>null</code> and generally will be) 066 */ 067 public UriParamQualifierEnum getQualifier() { 068 return myQualifier; 069 } 070 071 public String getValue() { 072 return myValue; 073 } 074 075 public StringDt getValueAsStringDt() { 076 return new StringDt(myValue); 077 } 078 079 public UriDt getValueAsUriDt() { 080 return new UriDt(myValue); 081 } 082 083 public String getValueNotNull() { 084 return defaultString(myValue); 085 } 086 087 public boolean isEmpty() { 088 return StringUtils.isEmpty(myValue); 089 } 090 091 /** 092 * Sets the qualifier for this param (may be <code>null</code> and generally will be) 093 * 094 * @return Returns a reference to <code>this</code> for easy method chanining 095 */ 096 public UriParam setQualifier(UriParamQualifierEnum theQualifier) { 097 myQualifier = theQualifier; 098 return this; 099 } 100 101 /** 102 * Sets the value for this param 103 * 104 * @return Returns a reference to <code>this</code> for easy method chanining 105 */ 106 public UriParam setValue(String theValue) { 107 myValue = theValue; 108 return this; 109 } 110 111 @Override 112 public String toString() { 113 ToStringBuilder builder = new ToStringBuilder(this, ToStringStyle.SHORT_PREFIX_STYLE); 114 builder.append("value", getValue()); 115 return builder.toString(); 116 } 117}