All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.datanucleus.store.rdbms.mapping.MappingCallbacks Maven / Gradle / Ivy

/**********************************************************************
Copyright (c) 2002 Mike Martin (TJDO) and others. All rights reserved. 
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Contributors:
2003 Andy Jefferson - coding standards
2007 Andy Jefferson - moved to be RelationMappingCallbacks
    ...
**********************************************************************/
package org.datanucleus.store.rdbms.mapping;

import org.datanucleus.state.DNStateManager;

/**
 * Interface defining a series of callbacks that are called when this mapping goes through certain lifecycle events. 
 * This interface would be implemented by any type of mapping that handles a relation and so may need to perform action just before or just after a lifecycle event.
 */
public interface MappingCallbacks
{
    /**
     * Method called after the insert of the object so that additional operations can be performed if necessary.
     * @param sm StateManager of the owner
     */
    default void postInsert(DNStateManager sm)
    {
        // Do nothing
    }

    /**
     * Method called after the retrieval of the object, so that additional operations can be performed if necessary.
     * @param sm StateManager of the owner
     */
    default void postFetch(DNStateManager sm)
    {
        // Do nothing
    }

    /**
     * Method called after the update of the object, so that additional operations can be performed if necessary.
     * @param sm StateManager of the owner
     */
    default void postUpdate(DNStateManager sm)
    {
        // Do nothing
    }

    /**
     * Method called before the delete of objects, so that additional operations can be performed if necessary.
     * @param sm StateManager of the owner
     */
    default void preDelete(DNStateManager sm)
    {
        // Do nothing
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy