/*
* Copyright 2014 JBoss 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 org.artificer.integration.artifactbuilder;
import java.util.List;
import java.util.ServiceLoader;
import org.oasis_open.docs.s_ramp.ns.s_ramp_v1.BaseArtifactType;
import org.artificer.common.ArtifactContent;
/**
* One or more {@link ArtifactBuilder}s are associated with one ArtifactBuilderProvider. {@link ArtifactBuilder} logic
* tends to be much cleaner when the builder is able to be *stateful*. Therefore, this service contract creates
* builders on demand, rather than singleton builder use.
*
* Register this service through a simple {@link ServiceLoader} registration. The following file should contain
* the FQN of your module's ArtifactBuilderProvider implementations, one per line:
*
* src/main/resources/META-INF/services/ArtifactBuilderProvider
*
* @author Brett Meyer
*/
public interface ArtifactBuilderProvider {
/**
* Provide a list of providers, applicable to the given {@link BaseArtifactType}. The whole artifact is provided
* in order to allow contextual logic.
*
* @param primaryArtifact
* @param artifactContent
* @return List<ArtifactBuilder>
*/
public List<ArtifactBuilder> createArtifactBuilders(BaseArtifactType primaryArtifact, ArtifactContent artifactContent);
}