/** * Abiquo community edition * cloud management application for hybrid clouds * Copyright (C) 2008-2010 - Abiquo Holdings S.L. * * This application is free software; you can redistribute it and/or * modify it under the terms of the GNU LESSER GENERAL PUBLIC * LICENSE as published by the Free Software Foundation under * version 3 of the License * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * LESSER GENERAL PUBLIC LICENSE v.3 for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ package com.abiquo.abicloud.taskservice.impl.executor; import static com.abiquo.abicloud.taskservice.utils.TaskUtils.getTaskMethod; import java.lang.reflect.Method; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.abiquo.abicloud.taskservice.exception.TaskServiceException; /** * A generic executor task. * * @author ibarrera */ public class ExecutorTask implements Runnable { /** * The logger. */ private static final Logger LOGGER = LoggerFactory.getLogger(ExecutorTask.class); /** * The target task to execute. */ private Class<?> targetClass; /** * The target method to execute. */ private Method targetMethod; /** * Creates a new {@link ExecutorTask} for the given task class. * * @throws TaskServiceException If task cannot be created. */ public ExecutorTask(final Class< ? > taskClass) throws TaskServiceException { super(); // Get task class and task method to execute this.targetClass = taskClass; this.targetMethod = getTaskMethod(taskClass); // Ensure that Task class can be instantiated try { this.targetClass.newInstance(); } catch (Exception ex) { throw new TaskServiceException("Could not instantiate task class: " + taskClass.getName(), ex); } } @Override public void run() { try { Object targetTask = targetClass.newInstance(); targetMethod.invoke(targetTask); } catch (Exception ex) { // TODO: Task exception handling LOGGER.error("An error occured while executing task {}", targetClass.getSimpleName()); } } }