csharp/rocketmq-client-csharp/TopicRouteData.cs (76 lines of code) (raw):
/*
* 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;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using Org.Apache.Rocketmq.Error;
using Proto = Apache.Rocketmq.V2;
namespace Org.Apache.Rocketmq
{
public class TopicRouteData : IEquatable<TopicRouteData>
{
private int _index = 0;
public TopicRouteData(IEnumerable<Proto.MessageQueue> messageQueues)
{
var messageQueuesList = messageQueues.Select(mq => new MessageQueue(mq)).ToList();
MessageQueues = messageQueuesList;
}
public List<MessageQueue> MessageQueues { get; }
public Endpoints PickEndpointsToQueryAssignments()
{
var nextIndex = Interlocked.Increment(ref _index) - 1;
foreach (var mq in MessageQueues)
{
var modIndex = Mod(nextIndex++, MessageQueues.Count);
var curMessageQueue = MessageQueues[modIndex];
if (Utilities.MasterBrokerId != curMessageQueue.Broker.Id)
{
continue;
}
if (Permission.None.Equals(curMessageQueue.Permission))
{
continue;
}
return curMessageQueue.Broker.Endpoints;
}
throw new NotFoundException("Failed to pick endpoints to query assignment");
}
private int Mod(int x, int m)
{
if (m <= 0)
{
throw new ArgumentException("Modulus must be positive", nameof(m));
}
var result = x % m;
return result >= 0 ? result : result + m;
}
public bool Equals(TopicRouteData other)
{
if (ReferenceEquals(null, other))
{
return false;
}
return ReferenceEquals(this, other) || Equals(MessageQueues, other.MessageQueues);
}
public override bool Equals(object obj)
{
if (ReferenceEquals(null, obj))
{
return false;
}
if (ReferenceEquals(this, obj))
{
return true;
}
return obj.GetType() == GetType() && Equals((TopicRouteData)obj);
}
public override int GetHashCode()
{
return (MessageQueues != null ? MessageQueues.GetHashCode() : 0);
}
public override string ToString()
{
var mqs = MessageQueues.Select(mq => mq.ToString()).ToList();
return $"[{string.Join(",", mqs)}]";
}
}
}