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

com.ibm.jbatch.container.services.impl.CDIBatchArtifactFactoryImpl Maven / Gradle / Ivy

The newest version!
/*
 * 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;

import java.util.logging.Logger;

import javax.enterprise.inject.spi.Bean;
import javax.enterprise.inject.spi.BeanManager;
import javax.naming.InitialContext;

import com.ibm.jbatch.container.exception.BatchContainerServiceException;
import com.ibm.jbatch.spi.services.IBatchArtifactFactory;
import com.ibm.jbatch.spi.services.IBatchConfig;

public class CDIBatchArtifactFactoryImpl implements IBatchArtifactFactory {

	private final static Logger logger = Logger.getLogger(CDIBatchArtifactFactoryImpl.class.getName());
	private final static String CLASSNAME = CDIBatchArtifactFactoryImpl.class.getName();

	@Override
	public Object load(String batchId) {
		String methodName = "load";

		logger.entering(CLASSNAME, methodName, "Loading batch artifact id = " + batchId);

		Object loadedArtifact = getArtifactById(batchId);

		if (loadedArtifact != null) {
			logger.exiting(CLASSNAME, methodName, "For batch artifact id = " + batchId + ", loaded artifact instance: " + loadedArtifact
					+ " of type: " + loadedArtifact.getClass().getCanonicalName());
		} else {
			logger.exiting(CLASSNAME, methodName, "For batch artifact id = " + batchId + ", FAILED to load artifact instance");
		}
		return loadedArtifact;
	}

	private Object getArtifactById(String id) {

		Object artifactInstance = null;

		try {
			InitialContext initialContext = new InitialContext();
			BeanManager bm = (BeanManager) initialContext.lookup("java:comp/BeanManager");
			Bean bean = bm.getBeans(id).iterator().next();
			Class clazz = bean.getBeanClass();
			artifactInstance = bm.getReference(bean, clazz, bm.createCreationalContext(bean));
		} catch (Exception e) {
			// Don't throw an exception but simply return null;
			logger.fine("Tried but failed to load artifact with id: " + id + ", Exception = " + e);
		}

		return artifactInstance;
	}

	@Override
	public void init(IBatchConfig batchConfig) throws BatchContainerServiceException {
		// TODO Auto-generated method stub

	}

	@Override
	public void shutdown() throws BatchContainerServiceException {
		// TODO Auto-generated method stub

	}


}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy