001/*- 002 * #%L 003 * HAPI FHIR - Server Framework 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.server.messaging.json; 021 022import ca.uhn.fhir.model.api.IModelJson; 023import com.fasterxml.jackson.annotation.JsonProperty; 024import jakarta.annotation.Nullable; 025import org.springframework.messaging.Message; 026import org.springframework.messaging.MessageHeaders; 027 028import static java.util.Objects.isNull; 029import static org.apache.commons.lang3.StringUtils.defaultString; 030 031public abstract class BaseJsonMessage<T> implements Message<T>, IModelJson { 032 033 private static final long serialVersionUID = 1L; 034 035 @JsonProperty("headers") 036 private HapiMessageHeaders myHeaders; 037 038 /** 039 * Constructor 040 */ 041 public BaseJsonMessage() { 042 super(); 043 setDefaultRetryHeaders(); 044 } 045 046 protected void setDefaultRetryHeaders() { 047 HapiMessageHeaders messageHeaders = new HapiMessageHeaders(); 048 setHeaders(messageHeaders); 049 } 050 051 @Override 052 public MessageHeaders getHeaders() { 053 return myHeaders.toMessageHeaders(); 054 } 055 056 public HapiMessageHeaders getHapiHeaders() { 057 if (isNull(myHeaders)) { 058 setDefaultRetryHeaders(); 059 } 060 return myHeaders; 061 } 062 063 public void setHeaders(HapiMessageHeaders theHeaders) { 064 myHeaders = theHeaders; 065 } 066 067 @Deprecated 068 @Nullable 069 public String getMessageKeyOrNull() { 070 return getMessageKey(); 071 } 072 073 @Nullable 074 public String getMessageKey() { 075 return null; 076 } 077 078 /** 079 * Returns {@link #getMessageKey()} or {@link #getMessageKeyDefaultValue()} when {@link #getMessageKey()} returns null. 080 * 081 * @return the message key value or default 082 */ 083 @Nullable 084 public String getMessageKeyOrDefault() { 085 return defaultString(getMessageKey(), getMessageKeyDefaultValue()); 086 } 087 088 /** 089 * Provides a fallback value when the value returned by {@link #getMessageKey()} is null. 090 * 091 * @return null by default 092 */ 093 @Nullable 094 protected String getMessageKeyDefaultValue() { 095 return null; 096 } 097}