001package ca.uhn.fhir.rest.server.interceptor;
002
003/*
004 * #%L
005 * HAPI FHIR - Core Library
006 * %%
007 * Copyright (C) 2014 - 2017 University Health Network
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 org.hl7.fhir.instance.model.api.IBaseResource;
024
025import ca.uhn.fhir.rest.method.RequestDetails;
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 */
034public interface IServerOperationInterceptor extends IServerInterceptor {
035
036        /**
037         * User code may call this method to indicate to an interceptor that
038         * a resource is being deleted
039         */
040        void resourceDeleted(RequestDetails theRequest, IBaseResource theResource);
041        
042        /**
043         * User code may call this method to indicate to an interceptor that
044         * a resource is being created
045         */
046        void resourceCreated(RequestDetails theRequest, IBaseResource theResource);
047
048        /**
049         * User code may call this method to indicate to an interceptor that
050         * a resource is being updated
051         */
052        void resourceUpdated(RequestDetails theRequest, IBaseResource theResource);
053
054}