mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-19 12:07:13 +01:00
4a6bfc086c
Switched to POCO library for unified platform/library interface. Deprecated the external module API. It was creating more problems than solving. Removed most built-in libraries in favor of system libraries for easier maintenance. Cleaned and secured code with help from static analyzers.
90 lines
1.4 KiB
C++
90 lines
1.4 KiB
C++
//
|
|
// ReplicaSet.cpp
|
|
//
|
|
// Library: MongoDB
|
|
// Package: MongoDB
|
|
// Module: ReplicaSet
|
|
//
|
|
// Copyright (c) 2012, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
//
|
|
|
|
|
|
#include "Poco/MongoDB/ReplicaSet.h"
|
|
#include "Poco/MongoDB/QueryRequest.h"
|
|
#include "Poco/MongoDB/ResponseMessage.h"
|
|
|
|
|
|
namespace Poco {
|
|
namespace MongoDB {
|
|
|
|
|
|
ReplicaSet::ReplicaSet(const std::vector<Net::SocketAddress> &addresses):
|
|
_addresses(addresses)
|
|
{
|
|
}
|
|
|
|
|
|
ReplicaSet::~ReplicaSet()
|
|
{
|
|
}
|
|
|
|
|
|
Connection::Ptr ReplicaSet::findMaster()
|
|
{
|
|
Connection::Ptr master;
|
|
|
|
for (std::vector<Net::SocketAddress>::iterator it = _addresses.begin(); it != _addresses.end(); ++it)
|
|
{
|
|
master = isMaster(*it);
|
|
if (!master.isNull())
|
|
{
|
|
break;
|
|
}
|
|
}
|
|
|
|
return master;
|
|
}
|
|
|
|
|
|
Connection::Ptr ReplicaSet::isMaster(const Net::SocketAddress& address)
|
|
{
|
|
Connection::Ptr conn = new Connection();
|
|
|
|
try
|
|
{
|
|
conn->connect(address);
|
|
|
|
QueryRequest request("admin.$cmd");
|
|
request.setNumberToReturn(1);
|
|
request.selector().add("isMaster", 1);
|
|
|
|
ResponseMessage response;
|
|
conn->sendRequest(request, response);
|
|
|
|
if (response.documents().size() > 0)
|
|
{
|
|
Document::Ptr doc = response.documents()[0];
|
|
if (doc->get<bool>("ismaster"))
|
|
{
|
|
return conn;
|
|
}
|
|
else if (doc->exists("primary"))
|
|
{
|
|
return isMaster(Net::SocketAddress(doc->get<std::string>("primary")));
|
|
}
|
|
}
|
|
}
|
|
catch (...)
|
|
{
|
|
conn = 0;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
} } // namespace Poco::MongoDB
|