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 org.springframework.messaging.MessageHeaders; 025 026import java.util.HashMap; 027import java.util.Map; 028 029import static java.util.Objects.isNull; 030 031/** 032 * This class is for holding headers for BaseJsonMessages. Any serializable data can be thrown into 033 * the header map. There are also three special headers, defined by the constants in this class, which are for use 034 * in message handling retrying. There are also matching helper functions for fetching those special variables; however 035 * they can also be accessed in standard map fashion with a `get` on the map. 036 */ 037public class HapiMessageHeaders implements IModelJson { 038 public static final String RETRY_COUNT_KEY = "retryCount"; 039 public static final String FIRST_FAILURE_KEY = "firstFailureTimestamp"; 040 public static final String LAST_FAILURE_KEY = "lastFailureTimestamp"; 041 042 @JsonProperty(RETRY_COUNT_KEY) 043 private Integer myRetryCount = 0; 044 045 @JsonProperty(FIRST_FAILURE_KEY) 046 private Long myFirstFailureTimestamp; 047 048 @JsonProperty(LAST_FAILURE_KEY) 049 private Long myLastFailureTimestamp; 050 051 @JsonProperty("customHeaders") 052 private final Map<String, Object> headers; 053 054 public HapiMessageHeaders(Map<String, Object> theHeaders) { 055 headers = theHeaders; 056 } 057 058 public HapiMessageHeaders() { 059 headers = new HashMap<>(); 060 } 061 062 public Integer getRetryCount() { 063 if (isNull(this.myRetryCount)) { 064 return 0; 065 } 066 return this.myRetryCount; 067 } 068 069 public Long getFirstFailureTimestamp() { 070 return this.myFirstFailureTimestamp; 071 } 072 073 public Long getLastFailureTimestamp() { 074 return this.myLastFailureTimestamp; 075 } 076 077 public void setRetryCount(Integer theRetryCount) { 078 this.myRetryCount = theRetryCount; 079 } 080 081 public void setLastFailureTimestamp(Long theLastFailureTimestamp) { 082 this.myLastFailureTimestamp = theLastFailureTimestamp; 083 } 084 085 public void setFirstFailureTimestamp(Long theFirstFailureTimestamp) { 086 this.myFirstFailureTimestamp = theFirstFailureTimestamp; 087 } 088 089 public Map<String, Object> getCustomHeaders() { 090 if (this.headers == null) { 091 return new HashMap<>(); 092 } 093 return this.headers; 094 } 095 096 public MessageHeaders toMessageHeaders() { 097 Map<String, Object> returnedHeaders = new HashMap<>(this.headers); 098 returnedHeaders.put(RETRY_COUNT_KEY, myRetryCount); 099 returnedHeaders.put(FIRST_FAILURE_KEY, myFirstFailureTimestamp); 100 returnedHeaders.put(LAST_FAILURE_KEY, myLastFailureTimestamp); 101 return new MessageHeaders(returnedHeaders); 102 } 103}