Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright 2012 International Business Machines Corp.
   * 
   * See the NOTICE file distributed with this work for additional information
   * regarding copyright ownership. 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 com.ibm.jbatch.container.services.impl;
 
 
 
 
 
     private static final String CLASSNAME = BatchTransactionServiceImpl.class.getName();
     private static final Logger logger = Logger.getLogger();
     
     private static final int DEFAULT_TRAN_TIMEOUT = 180; // seconds
 
    
batch configuration properties.
 
     private IBatchConfig batchConfig = null;

    
constructor
 
     public BatchTransactionServiceImpl() {
     }
 
     /*
      * (non-Javadoc)
      * 
      * @see
      * com.ibm.jbatch.container.services.IBatchServiceBase#init(com.ibm.batch
      * .container.IBatchConfig)
      */
     @Override
     public void init(IBatchConfig batchConfigthrows BatchContainerServiceException {
         .entering("init"batchConfig);
         this. = batchConfig;
         .exiting("init");
     }
 
     /*
      * (non-Javadoc)
      * 
      * @see com.ibm.jbatch.container.services.IBatchServiceBase#shutdown()
      */
     @Override
     public void shutdown() throws BatchContainerServiceException {
         .entering("shutdown");
         .fine("do nothing");
         .exiting("shutdown");
     }
 
     /*
      * (non-Javadoc)
      * 
      * @see com.ibm.jbatch.container.services.ITransactionManagementService#
      * getTransactionManager(javax.batch.runtime.context.StepContext)
      */
     @Override
         .entering("getTransactionManager"stepContext);
 
         TransactionManagerAdapter transactionManager = null;
 
         // get the JTA tran manager if we are in Java EE
         if (! this..isJ2seMode()) {
             // use the container JNDI java:comp/UserTransaction
             .fine("getting transaction object from JNDI java:comp/UserTransaction");
             transactionManager = new JTAUserTransactionAdapter("java:comp/UserTransaction");
         } 
         else if (this..isJ2seMode()) { 
         // If we are in J2SE mode use the non-transactional manager
         
             // java environment is Java SE
             // NoOp transaction manager
            .fine("J2SE mode non-transactional manager");
            transactionManager = new DefaultNonTransactionalManager();
        }
        int timeout = getTransactionTimeout(stepContext);
        .log(."transaction timeout {0}"timeout);
        try {
            transactionManager.setTransactionTimeout(timeout);
        } catch (Exception e) {
            throw new TransactionManagementException(e);
        }
        .exiting("getTransactionManager"transactionManager);
        return transactionManager;
    }


    

Parameters:
stepContext
Returns:
global transaction timeout defined in step properties. default timeout value is 180
    private int getTransactionTimeout(final StepContext stepContext) {
        .entering("getTransactionTimeout"stepContext);
        Properties p = stepContext.getProperties();
        int timeout = // default as per spec.
        if (p != null && !p.isEmpty()) {
            String timeOut = p.getProperty("javax.transaction.global.timeout");
            if (.isLoggable(.)) {
                .log(."javax.transaction.global.timeout = {0}"timeOut);
            }
            if (timeOut != null && !timeOut.isEmpty()) {
                timeout = Integer.parseInt(timeOut, 10);
            }
        }
        .exiting("getTransactionTimeout"timeout);
        return timeout;
    }
New to GrepCode? Check out our FAQ X