/*
* Copyright 2003-2005 The Apache Software Foundation.
*
* 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.apache.wsrp4j.commons.consumer.interfaces.producer;
import java.util.Iterator;
/**
* Defines a registry which can be used to administer
* producer objects.
*
* @version $Id: ProducerRegistry.java 374672 2006-02-03 14:10:58Z cziegeler $
*/
public interface ProducerRegistry {
/**
* Add a producer to the registry
*
* @param producer The producer to add
*/
void addProducer(Producer producer);
/**
* Get the producer for the given URL
*
* @param id The ID of the producer
*
* @return The producer with the given ID
**/
Producer getProducer(String id);
/**
* Get all producer in the registry
*
* @return Iterator with all producers
**/
Iterator getAllProducers();
/**
* Remove the producer with the given ID from the registry
*
* @param id The ID of the producer
*
* @return The producer which had been mapped to this id or
* null if no producer was found with this id
**/
Producer removeProducer(String id);
/**
* Remove all producer objects from the registry
**/
void removeAllProducers();
/**
* Check if a producer with the given ID exists in the registry.
*
* @param id The ID of the producer
*
* @return True if producer exists with this ID
**/
boolean existsProducer(String id);
}