Implement support for anonymous multicast messages.

Fixes #3545
This commit is contained in:
Gunnar Beutner 2013-01-22 10:14:52 +01:00
parent c2c7488089
commit c97b480b1e
5 changed files with 36 additions and 10 deletions

View File

@ -69,7 +69,7 @@ void DemoComponent::HelloWorldRequestHandler(const Endpoint::Ptr& sender,
const RequestMessage& request) const RequestMessage& request)
{ {
Logger::Write(LogInformation, "demo", "Got 'hello world' from identity=" + Logger::Write(LogInformation, "demo", "Got 'hello world' from identity=" +
sender->GetName()); (sender ? sender->GetName() : "(anonymous)"));
} }
EXPORT_COMPONENT(demo, DemoComponent); EXPORT_COMPONENT(demo, DemoComponent);

View File

@ -35,13 +35,13 @@ void ReplicationComponent::Start(void)
Endpoint::OnConnected.connect(boost::bind(&ReplicationComponent::EndpointConnectedHandler, this, _1)); Endpoint::OnConnected.connect(boost::bind(&ReplicationComponent::EndpointConnectedHandler, this, _1));
m_Endpoint->RegisterTopicHandler("config::ObjectUpdate", m_Endpoint->RegisterTopicHandler("config::ObjectUpdate",
boost::bind(&ReplicationComponent::RemoteObjectUpdateHandler, this, _2, _3)); boost::bind(&ReplicationComponent::RemoteObjectUpdateHandler, this, _3));
m_Endpoint->RegisterTopicHandler("config::ObjectRemoved", m_Endpoint->RegisterTopicHandler("config::ObjectRemoved",
boost::bind(&ReplicationComponent::RemoteObjectRemovedHandler, this, _3)); boost::bind(&ReplicationComponent::RemoteObjectRemovedHandler, this, _3));
/* service status */ /* service status */
m_Endpoint->RegisterTopicHandler("checker::ServiceStateChange", m_Endpoint->RegisterTopicHandler("checker::ServiceStateChange",
boost::bind(&ReplicationComponent::ServiceStateChangeRequestHandler, _2, _3)); boost::bind(&ReplicationComponent::ServiceStateChangeRequestHandler, _3));
} }
/** /**
@ -52,7 +52,7 @@ void ReplicationComponent::Stop(void)
m_Endpoint->Unregister(); m_Endpoint->Unregister();
} }
void ReplicationComponent::ServiceStateChangeRequestHandler(const Endpoint::Ptr& sender, const RequestMessage& request) void ReplicationComponent::ServiceStateChangeRequestHandler(const RequestMessage& request)
{ {
ServiceStateChangeMessage params; ServiceStateChangeMessage params;
if (!request.GetParams(&params)) if (!request.GetParams(&params))
@ -163,7 +163,7 @@ void ReplicationComponent::TransactionClosingHandler(const set<DynamicObject::Pt
} }
} }
void ReplicationComponent::RemoteObjectUpdateHandler(const Endpoint::Ptr& sender, const RequestMessage& request) void ReplicationComponent::RemoteObjectUpdateHandler(const RequestMessage& request)
{ {
MessagePart params; MessagePart params;
if (!request.GetParams(&params)) if (!request.GetParams(&params))

View File

@ -35,7 +35,7 @@ public:
private: private:
Endpoint::Ptr m_Endpoint; Endpoint::Ptr m_Endpoint;
static void ServiceStateChangeRequestHandler(const Endpoint::Ptr& sender, const RequestMessage& request); static void ServiceStateChangeRequestHandler(const RequestMessage& request);
void EndpointConnectedHandler(const Endpoint::Ptr& endpoint); void EndpointConnectedHandler(const Endpoint::Ptr& endpoint);
@ -43,7 +43,7 @@ private:
void LocalObjectUnregisteredHandler(const DynamicObject::Ptr& object); void LocalObjectUnregisteredHandler(const DynamicObject::Ptr& object);
void TransactionClosingHandler(const set<DynamicObject::Ptr>& modifiedObjects); void TransactionClosingHandler(const set<DynamicObject::Ptr>& modifiedObjects);
void RemoteObjectUpdateHandler(const Endpoint::Ptr& sender, const RequestMessage& request); void RemoteObjectUpdateHandler(const RequestMessage& request);
void RemoteObjectRemovedHandler(const RequestMessage& request); void RemoteObjectRemovedHandler(const RequestMessage& request);
static RequestMessage MakeObjectMessage(const DynamicObject::Ptr& object, static RequestMessage MakeObjectMessage(const DynamicObject::Ptr& object,

View File

@ -184,18 +184,31 @@ void EndpointManager::ClientClosedHandler(const Stream::Ptr& client)
m_PendingClients.erase(tlsStream); m_PendingClients.erase(tlsStream);
} }
/**
* Sends an anonymous unicast message to the specified recipient.
*
* @param recipient The recipient of the message.
* @param message The message.
*/
void EndpointManager::SendUnicastMessage(const Endpoint::Ptr& recipient,
const MessagePart& message)
{
SendUnicastMessage(Endpoint::Ptr(), recipient, message);
}
/** /**
* Sends a unicast message to the specified recipient. * Sends a unicast message to the specified recipient.
* *
* @param sender The sender of the message. * @param sender The sender of the message.
* @param recipient The recipient of the message. * @param recipient The recipient of the message.
* @param message The request. * @param message The message.
*/ */
void EndpointManager::SendUnicastMessage(const Endpoint::Ptr& sender, void EndpointManager::SendUnicastMessage(const Endpoint::Ptr& sender,
const Endpoint::Ptr& recipient, const MessagePart& message) const Endpoint::Ptr& recipient, const MessagePart& message)
{ {
/* don't forward messages between non-local endpoints */ /* don't forward messages between non-local endpoints, assume that
if (!sender->IsLocal() && !recipient->IsLocal()) * anonymous senders (sender == null) are local */
if ((sender && !sender->IsLocal()) && !recipient->IsLocal())
return; return;
if (ResponseMessage::IsResponseMessage(message)) if (ResponseMessage::IsResponseMessage(message))
@ -237,6 +250,17 @@ void EndpointManager::SendAnycastMessage(const Endpoint::Ptr& sender,
SendUnicastMessage(sender, recipient, message); SendUnicastMessage(sender, recipient, message);
} }
/**
* Sends an anonymous message to all recipients who have a subscription for the
* message#s topic.
*
* @param message The message.
*/
void EndpointManager::SendMulticastMessage(const RequestMessage& message)
{
SendMulticastMessage(Endpoint::Ptr(), message);
}
/** /**
* Sends a message to all recipients who have a subscription for the * Sends a message to all recipients who have a subscription for the
* message's topic. * message's topic.

View File

@ -47,8 +47,10 @@ public:
void AddListener(const String& service); void AddListener(const String& service);
void AddConnection(const String& node, const String& service); void AddConnection(const String& node, const String& service);
void SendUnicastMessage(const Endpoint::Ptr& recipient, const MessagePart& message);
void SendUnicastMessage(const Endpoint::Ptr& sender, const Endpoint::Ptr& recipient, const MessagePart& message); void SendUnicastMessage(const Endpoint::Ptr& sender, const Endpoint::Ptr& recipient, const MessagePart& message);
void SendAnycastMessage(const Endpoint::Ptr& sender, const RequestMessage& message); void SendAnycastMessage(const Endpoint::Ptr& sender, const RequestMessage& message);
void SendMulticastMessage(const RequestMessage& message);
void SendMulticastMessage(const Endpoint::Ptr& sender, const RequestMessage& message); void SendMulticastMessage(const Endpoint::Ptr& sender, const RequestMessage& message);
typedef function<void(const EndpointManager::Ptr&, const Endpoint::Ptr, const RequestMessage&, const ResponseMessage&, bool TimedOut)> APICallback; typedef function<void(const EndpointManager::Ptr&, const Endpoint::Ptr, const RequestMessage&, const ResponseMessage&, bool TimedOut)> APICallback;