⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 transactionphaselistener.java

📁 一个开源的rfid middleware 资料
💻 JAVA
字号:
/*
 * Copyright 2005 i-Konect LLC
 * 
 * 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 org.firstopen.singularity.admin;

import javax.faces.event.PhaseEvent;
import javax.faces.event.PhaseId;
import javax.faces.event.PhaseListener;
import javax.naming.NamingException;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.firstopen.singularity.util.InfrastructureException;
import org.firstopen.singularity.util.TransactionManager;

/**
 * 
 * PhaseListener that provides transaction support for all BackingBeans.
 * 
 * @author TomRose
 * @version $Id$
 * 
 */
public class TransactionPhaseListener implements PhaseListener {

    /**
     * 
     */
    private static final long serialVersionUID = -2432126487454834605L;

    private Log log = LogFactory.getLog(getClass());

    private TransactionManager tx = new TransactionManager();

    /**
     * @throws NamingException
     * 
     */
    public TransactionPhaseListener() {
        super();

    }

    /*
     * (non-Javadoc)
     * 
     * @see javax.faces.event.PhaseListener#beforePhase(javax.faces.event.PhaseEvent)
     */
    public void beforePhase(PhaseEvent event) {

        if (event.getPhaseId() == PhaseId.RESTORE_VIEW)
            log.debug("Processing new  Request!");

        log.debug("before - " + event.getPhaseId().toString());

        if (event.getPhaseId() == PhaseId.RESTORE_VIEW ||
            event.getPhaseId()==PhaseId.RENDER_RESPONSE) {
            tx.begin();
        }
    }

    /**
     * 
     * @see javax.faces.event.PhaseListener#afterPhase(javax.faces.event.PhaseEvent)
     */
    public void afterPhase(PhaseEvent event) {

        log.debug("after -  " + event.getPhaseId().toString());

        if (event.getPhaseId() == PhaseId.RENDER_RESPONSE ||
            event.getPhaseId() == PhaseId.INVOKE_APPLICATION) {
            log.debug("Done with Request, commit transaction...");
      
            try {
               
                tx.commit();
            } catch (InfrastructureException e) {
                log.error("commit failed, rollback transaction commencing");
                tx.rollback();
                throw e;
            }
        }
    }

    /*
     * (non-Javadoc)
     * 
     * @see javax.faces.event.PhaseListener#getPhaseId()
     */
    public PhaseId getPhaseId() {

        return PhaseId.ANY_PHASE;
    }

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -