001/*-
002 * #%L
003 * Smile CDR - CDR
004 * %%
005 * Copyright (C) 2016 - 2025 Smile CDR, Inc.
006 * %%
007 * All rights reserved.
008 * #L%
009 */
010package ca.cdr.api.fhirgw.model;
011
012import jakarta.annotation.Nonnull;
013import org.hl7.fhir.instance.model.api.IBaseResource;
014
015import java.util.Collections;
016import java.util.List;
017
018/**
019 * This class represents the response to a FHIR Gateway Search request
020 */
021public class SearchResponse extends BaseResponse<SearchResponse> {
022
023        @Nonnull
024        private List<IBaseResource> mySearchResults;
025
026        /**
027         * Constructor - Create an empty object
028         */
029        public SearchResponse() {
030                super();
031                mySearchResults = Collections.emptyList();
032        }
033
034        /**
035         * Copy constructor - Creates a shallow copy only
036         */
037        public SearchResponse(SearchResponse theSearchResponse) {
038                super(theSearchResponse);
039                mySearchResults = theSearchResponse.getSearchResults();
040        }
041
042        /**
043         * Provides the list of resources that were responded by the gateway target server.
044         * Interceptors may modify this list, modify entries in this list, or even add/remove entries
045         * from the list.
046         */
047        @Nonnull
048        public List<IBaseResource> getSearchResults() {
049                return mySearchResults;
050        }
051
052        /**
053         * Provides the list of resources that were responded by the gateway target server.
054         * Interceptors may modify this list, modify entries in this list, or even add/remove entries
055         * from the list.
056         */
057        public void setSearchResults(@Nonnull List<IBaseResource> theSearchResults) {
058                mySearchResults = theSearchResults;
059        }
060
061        /**
062         * Create a clone of this object using a <b>shallow copy only</b>. Values
063         * are copied by reference only, so things like Resources should only be
064         * modified if you are sure that the changes won't affect the value
065         * stored in cache.
066         */
067        @Override
068        public SearchResponse clone() {
069                return new SearchResponse(this);
070        }
071}