kr.debop4j.data.hibernate.interceptor.MultiInterceptor.java Source code

Java tutorial

Introduction

Here is the source code for kr.debop4j.data.hibernate.interceptor.MultiInterceptor.java

Source

/*
 * Copyright 2011-2013 the original author or authors.
 *
 * 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.
 */

package kr.debop4j.data.hibernate.interceptor;

import com.google.common.collect.Lists;
import lombok.Getter;
import lombok.Setter;
import org.hibernate.EmptyInterceptor;
import org.hibernate.Interceptor;
import org.hibernate.type.Type;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.Serializable;
import java.util.Iterator;
import java.util.List;
import java.util.concurrent.FutureTask;

/**
 *  ? Interceptor? ? ??  Interceptor. (? Interceptor  ? ? )
 *
 * @author ? ( sunghyouk.bae@gmail.com )
 * @since 12. 9. 23.
 */
public class MultiInterceptor extends EmptyInterceptor {

    private static final Logger log = LoggerFactory.getLogger(MultiInterceptor.class);
    private static final boolean isTraceEnabled = log.isTraceEnabled();
    private static final long serialVersionUID = 4354823013240170534L;

    @Getter
    @Setter
    private List<Interceptor> interceptors = Lists.newArrayList();

    /** Instantiates a new Multi interceptor. */
    public MultiInterceptor() {
    }

    /**
     * Instantiates a new Multi interceptor.
     *
     * @param interceptors the interceptors
     */
    public MultiInterceptor(List<Interceptor> interceptors) {
        this.interceptors = interceptors;
    }

    private boolean isExists() {
        return (interceptors != null && interceptors.size() > 0);
    }

    @Override
    public void onDelete(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) {

        if (!isExists())
            return;

        if (isTraceEnabled)
            log.trace("?? onDelete ? .");

        for (final Interceptor interceptor : interceptors) {
            interceptor.onDelete(entity, id, state, propertyNames, types);
        }
    }

    @Override
    public boolean onFlushDirty(Object entity, Serializable id, Object[] currentState, Object[] previousState,
            String[] propertyNames, Type[] types) {
        if (!isExists())
            return false;

        if (isTraceEnabled)
            log.trace("?? onFlush  ? .");

        for (final Interceptor interceptor : interceptors) {
            interceptor.onFlushDirty(entity, id, currentState, previousState, propertyNames, types);
        }

        return false;
    }

    @Override
    public boolean onLoad(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) {
        if (!isExists())
            return false;

        if (isTraceEnabled)
            log.trace("?? onLoad  ? .");

        for (final Interceptor interceptor : interceptors) {
            interceptor.onLoad(entity, id, state, propertyNames, types);
        }

        return false;
    }

    @Override
    public boolean onSave(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) {
        if (!isExists())
            return false;

        if (isTraceEnabled)
            log.trace("?? onSave  ? .");

        List<FutureTask<Boolean>> tasks = Lists.newLinkedList();

        for (final Interceptor interceptor : interceptors) {
            interceptor.onSave(entity, id, state, propertyNames, types);
        }

        return false;
    }

    @Override
    public void postFlush(Iterator entities) {
        if (!isExists())
            return;

        if (isTraceEnabled)
            log.trace("?? postFlush  ? .");

        // List<FutureTask<Void>> tasks = Lists.newLinkedList();

        for (final Interceptor interceptor : interceptors) {
            interceptor.postFlush(entities);
        }
    }

    @Override
    public void preFlush(Iterator entities) {
        if (!isExists())
            return;

        if (isTraceEnabled)
            log.trace("?? preFlush  ? .");

        // List<FutureTask<Void>> tasks = Lists.newLinkedList();

        for (final Interceptor interceptor : interceptors) {
            interceptor.preFlush(entities);
        }
    }
}