001/* 002 * #%L 003 * HAPI FHIR - Server Framework 004 * %% 005 * Copyright (C) 2014 - 2024 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; 021 022import ca.uhn.fhir.rest.api.server.IRestfulResponse; 023import ca.uhn.fhir.rest.api.server.RequestDetails; 024 025import java.util.ArrayList; 026import java.util.HashMap; 027import java.util.List; 028import java.util.Map; 029 030public abstract class BaseRestfulResponse<T extends RequestDetails> implements IRestfulResponse { 031 private final Map<String, List<String>> myHeaders = new HashMap<>(); 032 private T myRequestDetails; 033 034 public BaseRestfulResponse(T theRequestDetails) { 035 this.myRequestDetails = theRequestDetails; 036 } 037 038 @Override 039 public void addHeader(String headerKey, String headerValue) { 040 this.getHeaders().computeIfAbsent(headerKey, k -> new ArrayList<>()).add(headerValue); 041 } 042 043 /** 044 * Get the http headers 045 * 046 * @return the headers 047 */ 048 @Override 049 public Map<String, List<String>> getHeaders() { 050 return myHeaders; 051 } 052 053 /** 054 * Get the requestDetails 055 * 056 * @return the requestDetails 057 */ 058 public T getRequestDetails() { 059 return myRequestDetails; 060 } 061 062 /** 063 * Set the requestDetails 064 * 065 * @param requestDetails the requestDetails to set 066 */ 067 public void setRequestDetails(T requestDetails) { 068 this.myRequestDetails = requestDetails; 069 } 070}