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).",
030                      mask = true)
031    String getExpression();
032
033    @ManagedAttribute(description = "The uri delimiter to use")
034    String getUriDelimiter();
035
036    @ManagedAttribute(description = "Sets the maximum size used by the ProducerCache which is used to cache and reuse producers")
037    Integer getCacheSize();
038
039    @ManagedAttribute(description = "If enabled then the aggregate method on AggregationStrategy can be called concurrently.")
040    Boolean isParallelAggregate();
041
042    @ManagedAttribute(description = "If enabled then sending messages to the recipient lists occurs concurrently.")
043    Boolean isParallelProcessing();
044
045    @ManagedAttribute(description = "If enabled then Camel will process replies out-of-order, eg in the order they come back.")
046    Boolean isStreaming();
047
048    @ManagedAttribute(description = "Will now stop further processing if an exception or failure occurred during processing.")
049    Boolean isStopOnException();
050
051    @ManagedAttribute(description = "Shares the UnitOfWork with the parent and the resource exchange")
052    Boolean isShareUnitOfWork();
053
054    @ManagedAttribute(description = "The total timeout specified in millis, when using parallel processing.")
055    Long getTimeout();
056
057    @Override
058    @ManagedOperation(description = "Statistics of the endpoints which has been sent to")
059    TabularData extendedInformation();
060
061}