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

org.switchyard.config.model.composite.ComponentModel Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2013 Red Hat Inc. and/or its affiliates and other contributors.
 *
 * 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.switchyard.config.model.composite;

import java.util.List;
import java.util.Map;

import org.switchyard.common.property.PropertyResolver;
import org.switchyard.config.model.NamedModel;
import org.switchyard.config.model.property.PropertyModel;

/**
 * The "component" configuration model.
 *
 * @author David Ward <[email protected]> (C) 2011 Red Hat Inc.
 */
public interface ComponentModel extends NamedModel, PropertyResolver {

    /** The "component" name. */
    public static final String COMPONENT = "component";

    /**
     * Gets the parent composite model.
     * @return the parent composite model
     */
    public CompositeModel getComposite();

    /**
     * Gets the child component implementation model.
     * @return the child component implementation model
     */
    public ComponentImplementationModel getImplementation();

    /**
     * Sets the child copmonent implementation model.
     * @param implementation the child component implementation model
     * @return this ComponentModel (useful for chaining)
     */
    public ComponentModel setImplementation(ComponentImplementationModel implementation);

    /**
     * Gets the child component service models.
     * @return the child component service models
     */
    public List getServices();

    /**
     * Adds a child component service model.
     * @param service the child component service model
     * @return this ComponentModel (useful for chaining)
     */
    public ComponentModel addService(ComponentServiceModel service);

    /**
     * Gets the child component reference models.
     * @return the child component reference models
     */
    public List getReferences();

    /**
     * Adds a child component reference model.
     * @param reference the child component reference model
     * @return this ComponentModel (useful for chaining)
     */
    public ComponentModel addReference(ComponentReferenceModel reference);

    /**
     * Gets a child property model.
     * @param name property name to get
     * @return the child property model
     */
    public PropertyModel getProperty(String name);

    /**
     * Gets the map of child property model.
     * @return map of the child property model
     */
    public Map getProperties();
    
    /**
     * Sets the child properties model.
     * @param property the child property model
     * @return this ComponentModel (useful for chaining)
     */
    public ComponentModel addProperty(PropertyModel property);

    /**
     * Sets the component property resolver based on the current state of the model.
     */
    public void setComponentPropertyResolver();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy