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

com.netflix.hystrix.contrib.javanica.command.BatchHystrixCommand Maven / Gradle / Ivy

The newest version!
/**
 * Copyright 2012 Netflix, Inc.
 * 

* 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.netflix.hystrix.contrib.javanica.command; import com.netflix.hystrix.HystrixCollapser; import com.netflix.hystrix.contrib.javanica.exception.FallbackInvocationException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import javax.annotation.concurrent.ThreadSafe; import java.util.ArrayList; import java.util.Collection; import java.util.List; import static com.netflix.hystrix.contrib.javanica.exception.ExceptionUtils.unwrapCause; import static com.netflix.hystrix.contrib.javanica.utils.CommonUtils.createArgsForFallback; /** * This command is used in collapser. */ @ThreadSafe public class BatchHystrixCommand extends AbstractHystrixCommand> { private static final Logger LOGGER = LoggerFactory.getLogger(BatchHystrixCommand.class); public BatchHystrixCommand(HystrixCommandBuilder builder) { super(builder); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") protected List run() throws Exception { Object[] args = toArgs(getCollapsedRequests()); return (List) process(args); } private Object process(final Object[] args) throws Exception { return process(new Action() { @Override Object execute() { return getCommandAction().executeWithArgs(getExecutionType(), args); } }); } @Override @SuppressWarnings("unchecked") protected List getFallback() { if (getFallbackAction() != null) { final CommandAction commandAction = getFallbackAction(); try { return (List) process(new Action() { @Override Object execute() { MetaHolder metaHolder = commandAction.getMetaHolder(); Object[] args = toArgs(getCollapsedRequests()); args = createArgsForFallback(args, metaHolder, getExecutionException()); return commandAction.executeWithArgs(commandAction.getMetaHolder().getFallbackExecutionType(), args); } }); } catch (Throwable e) { LOGGER.error(FallbackErrorMessageBuilder.create() .append(commandAction, e).build()); throw new FallbackInvocationException(unwrapCause(e)); } } else { return super.getFallback(); } } private Object[] toArgs(Collection> requests) { return new Object[]{collect(requests)}; } private List collect(Collection> requests) { List commandArgs = new ArrayList(); for (HystrixCollapser.CollapsedRequest request : requests) { final Object[] args = (Object[]) request.getArgument(); commandArgs.add(args[0]); } return commandArgs; } }