001/**
002 * Licensed to the Apache Software Foundation (ASF) under one or more
003 * contributor license agreements.  See the NOTICE file distributed with
004 * this work for additional information regarding copyright ownership.
005 * The ASF licenses this file to You under the Apache License, Version 2.0
006 * (the "License"); you may not use this file except in compliance with
007 * the License.  You may obtain a copy of the License at
008 *
009 *      http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017package org.apache.camel.api.management.mbean;
018
019import javax.management.openmbean.TabularData;
020
021import org.apache.camel.api.management.ManagedAttribute;
022import org.apache.camel.api.management.ManagedOperation;
023
024public interface ManagedRecipientListMBean extends ManagedProcessorMBean, ManagedExtendedInformation {
025
026    @ManagedAttribute(description = "The language for the expression")
027    String getExpressionLanguage();
028
029    @ManagedAttribute(description = "Expression that returns which endpoints (url) to send the message to (the recipients).", mask = true)
030    String getExpression();
031
032    @ManagedAttribute(description = "The uri delimiter to use")
033    String getUriDelimiter();
034
035    @ManagedAttribute(description = "Sets the maximum size used by the ProducerCache which is used to cache and reuse producers")
036    Integer getCacheSize();
037
038    @ManagedAttribute(description = "If enabled then the aggregate method on AggregationStrategy can be called concurrently.")
039    Boolean isParallelAggregate();
040
041    @ManagedAttribute(description = "If enabled then sending messages to the recipient lists occurs concurrently.")
042    Boolean isParallelProcessing();
043
044    @ManagedAttribute(description = "If enabled then Camel will process replies out-of-order, eg in the order they come back.")
045    Boolean isStreaming();
046
047    @ManagedAttribute(description = "Will now stop further processing if an exception or failure occurred during processing.")
048    Boolean isStopOnException();
049
050    @ManagedAttribute(description = "Shares the UnitOfWork with the parent and the resource exchange")
051    Boolean isShareUnitOfWork();
052
053    @ManagedAttribute(description = "The total timeout specified in millis, when using parallel processing.")
054    Long getTimeout();
055
056    @ManagedOperation(description = "Statistics of the endpoints which has been sent to")
057    TabularData extendedInformation();
058
059}