001package ca.uhn.fhir.rest.api;
002
003/*
004 * #%L
005 * HAPI FHIR - Core Library
006 * %%
007 * Copyright (C) 2014 - 2022 Smile CDR, Inc.
008 * %%
009 * Licensed under the Apache License, Version 2.0 (the "License");
010 * you may not use this file except in compliance with the License.
011 * You may obtain a copy of the License at
012 *
013 *      http://www.apache.org/licenses/LICENSE-2.0
014 *
015 * Unless required by applicable law or agreed to in writing, software
016 * distributed under the License is distributed on an "AS IS" BASIS,
017 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
018 * See the License for the specific language governing permissions and
019 * limitations under the License.
020 * #L%
021 */
022
023import ca.uhn.fhir.context.api.BundleInclusionRule;
024import ca.uhn.fhir.model.api.Include;
025import ca.uhn.fhir.model.valueset.BundleTypeEnum;
026import org.hl7.fhir.instance.model.api.IBaseResource;
027import org.hl7.fhir.instance.model.api.IPrimitiveType;
028
029import javax.annotation.Nonnull;
030import java.util.ArrayList;
031import java.util.Date;
032import java.util.List;
033import java.util.Set;
034
035/**
036 * This interface should be considered experimental and will likely change in future releases of HAPI. Use with caution!
037 */
038public interface IVersionSpecificBundleFactory {
039
040        void addResourcesToBundle(List<IBaseResource> theResult, BundleTypeEnum theBundleType, String theServerBase, BundleInclusionRule theBundleInclusionRule, Set<Include> theIncludes);
041
042        void addRootPropertiesToBundle(String theId, @Nonnull BundleLinks theBundleLinks, Integer theTotalResults, IPrimitiveType<Date> theLastUpdated);
043
044        IBaseResource getResourceBundle();
045
046        /**
047         * @deprecated This was deprecated in HAPI FHIR 4.1.0 as it provides duplicate functionality to the {@link #addRootPropertiesToBundle(String, BundleLinks, Integer, IPrimitiveType<Date>)}
048         * and {@link #addResourcesToBundle(List, BundleTypeEnum, String, BundleInclusionRule, Set)} methods
049         */
050        @Deprecated
051        default void initializeBundleFromResourceList(String theAuthor, List<? extends IBaseResource> theResult, String theServerBase, String theCompleteUrl, int theTotalResults, BundleTypeEnum theBundleType) {
052                addTotalResultsToBundle(theResult.size(), theBundleType);
053                addResourcesToBundle(new ArrayList<>(theResult), theBundleType, null, null, null);
054        }
055
056        void initializeWithBundleResource(IBaseResource theResource);
057
058        List<IBaseResource> toListOfResources();
059
060        void addTotalResultsToBundle(Integer theTotalResults, BundleTypeEnum theBundleType);
061}