/*
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*
*/
using System;
namespace Apache.Qpid.Client.Qms.Failover
{
public class FailoverMethodConstants
{
public const String ROUND_ROBIN = "roundrobin";
public const String RANDOM = "random";
}
public interface IFailoverMethod
{
///
/// The name of this method for display purposes.
///
String MethodName { get; }
///
/// Reset the Failover to initial conditions
///
void Reset();
///
/// Check if failover is possible for this method
///
/// true if failover is allowed
bool FailoverAllowed();
///
/// Notification to the Failover method that a connection has been attained.
///
void AttainedConnection();
///
/// If there is no current BrokerInfo the null will be returned.
///
/// The current BrokerDetail value to use
IBrokerInfo GetCurrentBrokerInfo();
///
/// Move to the next BrokerInfo if one is available.
///
/// the next BrokerDetail or null if there is none.
IBrokerInfo GetNextBrokerDetails();
///
/// Set the currently active broker to be the new value.
///
/// The new BrokerDetail value
void SetBroker(IBrokerInfo broker);
///
/// Set the retries for this method
///
/// the maximum number of time to retry this Method
void SetRetries(int maxRetries);
}
}