/* * Copyright (c) 2015 Red Hat, Inc. and/or its affiliates. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html */ package org.jberet.tools; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.LinkedHashSet; import java.util.Set; import org.jberet.spi.JobXmlResolver; /** * A job XML resolver for chaining resolvers. * * @author <a href="mailto:jperkins@redhat.com">James R. Perkins</a> */ public class ChainedJobXmlResolver implements JobXmlResolver { private final Set<JobXmlResolver> resolvers; /** * Creates a new chained job XML resolver. * * @param resolvers the resolvers to use */ public ChainedJobXmlResolver(final JobXmlResolver... resolvers) { this.resolvers = new LinkedHashSet<JobXmlResolver>(resolvers.length); Collections.addAll(this.resolvers, resolvers); } /** * Creates a new chained job XML resolver. * * @param resolvers the resolvers to use */ public ChainedJobXmlResolver(final Iterable<JobXmlResolver> resolvers) { this.resolvers = new LinkedHashSet<JobXmlResolver>(); for (JobXmlResolver resolver : resolvers) { this.resolvers.add(resolver); } } /** * Creates a new chained job XML resolver. * * @param resolvers the resolvers to use * @param additionalResolvers any additional resolvers to use */ public ChainedJobXmlResolver(final Iterable<JobXmlResolver> resolvers, final JobXmlResolver... additionalResolvers) { this.resolvers = new LinkedHashSet<JobXmlResolver>(); for (JobXmlResolver resolver : resolvers) { this.resolvers.add(resolver); } Collections.addAll(this.resolvers, additionalResolvers); } /** * Creates a new chained job XML resolver. * * @param resolvers the resolvers to use */ public ChainedJobXmlResolver(final Collection<JobXmlResolver> resolvers) { this.resolvers = new LinkedHashSet<JobXmlResolver>(resolvers); } /** * {@inheritDoc} * <p> * Each resolver is checked until the first one returns a {@code non-null} value after which no other resolvers are * checked. If no resolver finds the content {@code null} will be returned. * </p> */ @Override public InputStream resolveJobXml(final String jobXml, final ClassLoader classLoader) throws IOException { for (JobXmlResolver resolver : resolvers) { final InputStream is = resolver.resolveJobXml(jobXml, classLoader); if (is != null) { return is; } } return null; } /** * {@inheritDoc} * <p> * Gets the names for each resolver and returns all the names found. * </p> */ @Override public Collection<String> getJobXmlNames(final ClassLoader classLoader) { final Collection<String> names = new ArrayList<String>(); for (JobXmlResolver resolver : resolvers) { names.addAll(resolver.getJobXmlNames(classLoader)); } return names; } /** * {@inheritDoc} * <p> * Checks each resolver until a {@code non-null} value is found. If the name could not be resolved by any resolver * {@code null} is returned. * </p> */ @Override public String resolveJobName(final String jobXml, final ClassLoader classLoader) { for (JobXmlResolver resolver : resolvers) { final String name = resolver.resolveJobName(jobXml, classLoader); if (name != null) { return name; } } return null; } }