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.provider;
021
022import ca.uhn.fhir.rest.annotation.Operation;
023import ca.uhn.fhir.rest.annotation.OperationParam;
024import ca.uhn.fhir.rest.api.Constants;
025import ca.uhn.fhir.rest.server.servlet.ServletRequestDetails;
026import org.hl7.fhir.instance.model.api.IBaseBundle;
027import org.hl7.fhir.instance.model.api.IBaseCoding;
028import org.hl7.fhir.instance.model.api.IBaseReference;
029import org.hl7.fhir.instance.model.api.IPrimitiveType;
030
031import java.util.List;
032
033/**
034 * This class implements the Observation
035 * <a href="http://hl7.org/fhir/observation-operation-lastn.html">$lastn</a> operation.
036 * <p>
037 * It is does not implement the actual storage logic for this operation, but can be
038 * subclassed to provide this functionality.
039 * </p>
040 *
041 * @since 4.1.0
042 */
043public abstract class BaseLastNProvider {
044
045        @Operation(name = Constants.OPERATION_LASTN, typeName = "Observation", idempotent = true)
046        public IBaseBundle lastN(
047                        ServletRequestDetails theRequestDetails,
048                        @OperationParam(name = "subject", typeName = "reference", min = 0, max = 1) IBaseReference theSubject,
049                        @OperationParam(name = "category", typeName = "coding", min = 0, max = OperationParam.MAX_UNLIMITED)
050                                        List<IBaseCoding> theCategories,
051                        @OperationParam(name = "code", typeName = "coding", min = 0, max = OperationParam.MAX_UNLIMITED)
052                                        List<IBaseCoding> theCodes,
053                        @OperationParam(name = "max", typeName = "integer", min = 0, max = 1) IPrimitiveType<Integer> theMax) {
054                return processLastN(theSubject, theCategories, theCodes, theMax);
055        }
056
057        /**
058         * Subclasses should implement this method
059         */
060        protected abstract IBaseBundle processLastN(
061                        IBaseReference theSubject,
062                        List<IBaseCoding> theCategories,
063                        List<IBaseCoding> theCodes,
064                        IPrimitiveType<Integer> theMax);
065}