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.interceptor; 021 022import ca.uhn.fhir.interceptor.api.Hook; 023import ca.uhn.fhir.interceptor.api.Pointcut; 024import ca.uhn.fhir.rest.api.server.RequestDetails; 025import org.hl7.fhir.instance.model.api.IBaseResource; 026 027/** 028 * Server interceptor with added methods which can be called within the lifecycle of 029 * write operations (create/update/delete) or within transaction and batch 030 * operations that call these sub-operations. 031 * 032 * @see ServerOperationInterceptorAdapter 033 * @deprecated Ths interface is no longer neccessary as of HAPI FHIR 3.8.0 - You can create 034 * interceptor methods that are declared using the {@link Hook} annotation without needing 035 * to implement any interceptor 036 */ 037@Deprecated 038public interface IServerOperationInterceptor extends IServerInterceptor { 039 040 /** 041 * This method is called by the server immediately after a resource has 042 * been created, within the database transaction scope of the operation. 043 * <p> 044 * If an exception is thrown by an interceptor during this method, 045 * the transaction will be rolled back. 046 * </p> 047 */ 048 @Hook(Pointcut.STORAGE_PRECOMMIT_RESOURCE_CREATED) 049 void resourceCreated(RequestDetails theRequest, IBaseResource theResource); 050 051 /** 052 * This method is called by the server immediately after a resource has 053 * been deleted, within the database transaction scope of the operation. 054 * <p> 055 * If an exception is thrown by an interceptor during this method, 056 * the transaction will be rolled back. 057 * </p> 058 */ 059 @Hook(Pointcut.STORAGE_PRECOMMIT_RESOURCE_DELETED) 060 void resourceDeleted(RequestDetails theRequest, IBaseResource theResource); 061 062 /** 063 * This method is called by the server immediately before a resource is about 064 * to be created, within the database transaction scope of the operation. 065 * <p> 066 * This method may be used to modify the resource 067 * </p> 068 * <p> 069 * If an exception is thrown by an interceptor during this method, 070 * the transaction will be rolled back. 071 * </p> 072 * 073 * @param theResource The resource that has been provided by the client as the payload 074 * to create. Interceptors may modify this 075 * resource, and modifications will affect what is saved in the database. 076 */ 077 @Hook(Pointcut.STORAGE_PRESTORAGE_RESOURCE_CREATED) 078 void resourcePreCreate(RequestDetails theRequest, IBaseResource theResource); 079 080 /** 081 * This method is called by the server immediately before a resource is about 082 * to be deleted, within the database transaction scope of the operation. 083 * <p> 084 * If an exception is thrown by an interceptor during this method, 085 * the transaction will be rolled back. 086 * </p> 087 * 088 * @param theResource The resource which is about to be deleted 089 */ 090 @Hook(Pointcut.STORAGE_PRESTORAGE_RESOURCE_DELETED) 091 void resourcePreDelete(RequestDetails theRequest, IBaseResource theResource); 092 093 /** 094 * This method is called by the server immediately before a resource is about 095 * to be updated, within the database transaction scope of the operation. 096 * <p> 097 * This method may be used to modify the resource 098 * </p> 099 * <p> 100 * If an exception is thrown by an interceptor during this method, 101 * the transaction will be rolled back. 102 * </p> 103 * 104 * @param theOldResource The previous version of the resource, or <code>null</code> if this is not available. Interceptors should be able to handle situations where this is null, since it is not always 105 * convenient or possible to provide a value for this field, but servers should try to populate it. 106 * @param theNewResource The resource that has been provided by the client as the payload 107 * to update to the resource to. Interceptors may modify this 108 * resource, and modifications will affect what is saved in the database. 109 */ 110 @Hook(Pointcut.STORAGE_PRESTORAGE_RESOURCE_UPDATED) 111 void resourcePreUpdate(RequestDetails theRequest, IBaseResource theOldResource, IBaseResource theNewResource); 112 113 /** 114 * @deprecated Deprecated in HAPI FHIR 3.0.0 in favour of {@link #resourceUpdated(RequestDetails, IBaseResource, IBaseResource)} 115 */ 116 @Deprecated 117 @Hook(Pointcut.STORAGE_PRECOMMIT_RESOURCE_UPDATED) 118 void resourceUpdated(RequestDetails theRequest, IBaseResource theResource); 119 120 /** 121 * This method is called by the server immediately after a resource has 122 * been created, within the database transaction scope of the operation. 123 * <p> 124 * If an exception is thrown by an interceptor during this method, 125 * the transaction will be rolled back. 126 * </p> 127 * 128 * @param theOldResource The resource as it was before the update, or <code>null</code> if this is not available. Interceptors should be able to handle situations where this is null, since it is not always 129 * convenient or possible to provide a value for this field, but servers should try to populate it. 130 * @param theNewResource The resource as it will be after the update 131 */ 132 @Hook(Pointcut.STORAGE_PRECOMMIT_RESOURCE_UPDATED) 133 void resourceUpdated(RequestDetails theRequest, IBaseResource theOldResource, IBaseResource theNewResource); 134}