001package ca.uhn.fhir.subscription.api; 002 003/*- 004 * #%L 005 * HAPI FHIR Storage api 006 * %% 007 * Copyright (C) 2014 - 2025 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.jpa.model.entity.IPersistedResourceModifiedMessage; 024import ca.uhn.fhir.jpa.model.entity.IPersistedResourceModifiedMessagePK; 025import ca.uhn.fhir.jpa.subscription.model.ResourceModifiedMessage; 026import org.springframework.data.domain.Page; 027import org.springframework.data.domain.Pageable; 028 029import java.util.Optional; 030 031/** 032 * An implementer of this interface will provide {@link ResourceModifiedMessage} persistence services. 033 * 034 * Client of this interface should persist ResourceModifiedMessage as part of the processing of an operation on 035 * a resource. Upon a successful submission to the subscription pipeline, the persisted message should be deleted. 036 * When submission fails, the message should be left un-altered for re-submission at a later time (see {@link IResourceModifiedConsumerWithRetries}). 037 */ 038public interface IResourceModifiedMessagePersistenceSvc { 039 040 /** 041 * Find all persistedResourceModifiedMessage sorted by ascending created dates (oldest to newest). 042 * @param thePageable Page request 043 * @return A sorted list of persistedResourceModifiedMessage needing submission. 044 */ 045 Page<IPersistedResourceModifiedMessage> findAllOrderedByCreatedTime(Pageable thePageable); 046 047 /** 048 * Delete a persistedResourceModifiedMessage by its primary key. 049 * 050 * @param thePersistedResourceModifiedMessagePK The primary key of the persistedResourceModifiedMessage to delete. 051 * @return Whether the persistedResourceModifiedMessage pointed to by <code>theResourceModifiedPK</code> was deleted. 052 */ 053 boolean deleteByPK(IPersistedResourceModifiedMessagePK thePersistedResourceModifiedMessagePK); 054 055 /** 056 * Persist a resourceModifiedMessage and return its resulting persisted representation. 057 * 058 * @param theMsg The resourceModifiedMessage to persist. 059 * @return The persisted representation of <code>theMsg</code>. 060 */ 061 IPersistedResourceModifiedMessage persist(ResourceModifiedMessage theMsg); 062 063 /** 064 * Restore a resourceModifiedMessage to its pre persistence representation. 065 * 066 * @param theResourceModifiedMessage The message needing restoration. 067 * @return The resourceModifiedMessage in its pre persistence form. 068 */ 069 ResourceModifiedMessage inflatePersistedResourceModifiedMessage(ResourceModifiedMessage theResourceModifiedMessage); 070 071 /** 072 * Restore a resourceModifiedMessage to its pre persistence representation or null if the resource does not exist. 073 * 074 * @param theResourceModifiedMessage 075 * @return An Optional containing The resourceModifiedMessage in its pre persistence form or null when the resource 076 * does not exist 077 */ 078 Optional<ResourceModifiedMessage> inflatePersistedResourceModifiedMessageOrNull( 079 ResourceModifiedMessage theResourceModifiedMessage); 080 081 /** 082 * Create a ResourceModifiedMessage without its pre persistence representation, i.e. without the resource body in 083 * payload 084 * 085 * @param thePersistedResourceModifiedMessage The message needing creation 086 * @return The resourceModifiedMessage without its pre persistence form 087 */ 088 ResourceModifiedMessage createResourceModifiedMessageFromEntityWithoutInflation( 089 IPersistedResourceModifiedMessage thePersistedResourceModifiedMessage); 090 091 /** 092 * 093 * @return the number of persisted resourceModifiedMessage. 094 */ 095 long getMessagePersistedCount(); 096}