mirror of
https://github.com/pocoproject/poco.git
synced 2024-12-13 10:32:57 +01:00
chore(MongoDB): Mark some old wire protocol functions as deprecated. (#4782)
This commit is contained in:
parent
cecccf7b74
commit
29b2c3a7b7
@ -26,8 +26,7 @@
|
|||||||
namespace Poco {
|
namespace Poco {
|
||||||
namespace MongoDB {
|
namespace MongoDB {
|
||||||
|
|
||||||
//class [[deprecated]] Cursor;
|
class POCO_DEPRECATED("Use new wire protocol") Cursor;
|
||||||
class Cursor;
|
|
||||||
|
|
||||||
class MongoDB_API Cursor: public Document
|
class MongoDB_API Cursor: public Document
|
||||||
/// Cursor is an helper class for querying multiple documents.
|
/// Cursor is an helper class for querying multiple documents.
|
||||||
|
@ -81,7 +81,7 @@ public:
|
|||||||
/// Creates a QueryRequest to count the given collection.
|
/// Creates a QueryRequest to count the given collection.
|
||||||
/// The collectionname must not contain the database name. (old wire protocol)
|
/// The collectionname must not contain the database name. (old wire protocol)
|
||||||
|
|
||||||
//[[deprecated]]
|
POCO_DEPRECATED("Use new wire protocol")
|
||||||
Poco::SharedPtr<Poco::MongoDB::DeleteRequest> createDeleteRequest(const std::string& collectionName) const;
|
Poco::SharedPtr<Poco::MongoDB::DeleteRequest> createDeleteRequest(const std::string& collectionName) const;
|
||||||
/// Creates a DeleteRequest to delete documents in the given collection.
|
/// Creates a DeleteRequest to delete documents in the given collection.
|
||||||
/// The collectionname must not contain the database name. (old wire protocol)
|
/// The collectionname must not contain the database name. (old wire protocol)
|
||||||
@ -96,7 +96,7 @@ public:
|
|||||||
/// Creates a QueryRequest. (old wire protocol)
|
/// Creates a QueryRequest. (old wire protocol)
|
||||||
/// The collectionname must not contain the database name.
|
/// The collectionname must not contain the database name.
|
||||||
|
|
||||||
//[[deprecated]]
|
POCO_DEPRECATED("Use new wire protocol")
|
||||||
Poco::SharedPtr<Poco::MongoDB::UpdateRequest> createUpdateRequest(const std::string& collectionName) const;
|
Poco::SharedPtr<Poco::MongoDB::UpdateRequest> createUpdateRequest(const std::string& collectionName) const;
|
||||||
/// Creates an UpdateRequest. (old wire protocol)
|
/// Creates an UpdateRequest. (old wire protocol)
|
||||||
/// The collectionname must not contain the database name.
|
/// The collectionname must not contain the database name.
|
||||||
|
@ -26,8 +26,7 @@
|
|||||||
namespace Poco {
|
namespace Poco {
|
||||||
namespace MongoDB {
|
namespace MongoDB {
|
||||||
|
|
||||||
//class [[deprecated]] DeleteRequest;
|
//class POCO_DEPRECATED("Use new wire protocol") DeleteRequest;
|
||||||
class DeleteRequest;
|
|
||||||
|
|
||||||
class MongoDB_API DeleteRequest: public RequestMessage
|
class MongoDB_API DeleteRequest: public RequestMessage
|
||||||
/// A DeleteRequest is used to delete one ore more documents from a database.
|
/// A DeleteRequest is used to delete one ore more documents from a database.
|
||||||
|
@ -26,8 +26,7 @@
|
|||||||
namespace Poco {
|
namespace Poco {
|
||||||
namespace MongoDB {
|
namespace MongoDB {
|
||||||
|
|
||||||
//class [[deprecated]] UpdateRequest;
|
//class POCO_DEPRECATED("Use new wire protocol") UpdateRequest;
|
||||||
class UpdateRequest;
|
|
||||||
|
|
||||||
class MongoDB_API UpdateRequest: public RequestMessage
|
class MongoDB_API UpdateRequest: public RequestMessage
|
||||||
/// This request is used to update a document in a database
|
/// This request is used to update a document in a database
|
||||||
|
@ -81,7 +81,7 @@ namespace
|
|||||||
std::string digestToBinaryString(Poco::DigestEngine& engine)
|
std::string digestToBinaryString(Poco::DigestEngine& engine)
|
||||||
{
|
{
|
||||||
Poco::DigestEngine::Digest d = engine.digest();
|
Poco::DigestEngine::Digest d = engine.digest();
|
||||||
return std::string(reinterpret_cast<const char*>(&d[0]), d.size());
|
return { reinterpret_cast<const char*>(&d[0]), d.size() };
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string digestToHexString(Poco::DigestEngine& engine)
|
std::string digestToHexString(Poco::DigestEngine& engine)
|
||||||
@ -116,7 +116,7 @@ namespace
|
|||||||
}
|
}
|
||||||
return digestToHexString(md5);
|
return digestToHexString(md5);
|
||||||
}
|
}
|
||||||
}
|
} // namespace
|
||||||
|
|
||||||
|
|
||||||
Database::Database(const std::string& db):
|
Database::Database(const std::string& db):
|
||||||
@ -152,14 +152,16 @@ bool Database::authCR(Connection& connection, const std::string& username, const
|
|||||||
|
|
||||||
ResponseMessage response;
|
ResponseMessage response;
|
||||||
connection.sendRequest(*pCommand, response);
|
connection.sendRequest(*pCommand, response);
|
||||||
if (response.documents().size() > 0)
|
if (response.documents().empty())
|
||||||
|
{
|
||||||
|
throw Poco::ProtocolException("empty response for getnonce");
|
||||||
|
}
|
||||||
{
|
{
|
||||||
Document::Ptr pDoc = response.documents()[0];
|
Document::Ptr pDoc = response.documents()[0];
|
||||||
if (pDoc->getInteger("ok") != 1) return false;
|
if (pDoc->getInteger("ok") != 1) return false;
|
||||||
nonce = pDoc->get<std::string>("nonce", "");
|
nonce = pDoc->get<std::string>("nonce", "");
|
||||||
if (nonce.empty()) throw Poco::ProtocolException("no nonce received");
|
if (nonce.empty()) throw Poco::ProtocolException("no nonce received");
|
||||||
}
|
}
|
||||||
else throw Poco::ProtocolException("empty response for getnonce");
|
|
||||||
|
|
||||||
std::string credsDigest = hashCredentials(username, password);
|
std::string credsDigest = hashCredentials(username, password);
|
||||||
|
|
||||||
@ -177,12 +179,12 @@ bool Database::authCR(Connection& connection, const std::string& username, const
|
|||||||
.add<std::string>("key", key);
|
.add<std::string>("key", key);
|
||||||
|
|
||||||
connection.sendRequest(*pCommand, response);
|
connection.sendRequest(*pCommand, response);
|
||||||
if (response.documents().size() > 0)
|
if (!response.documents().empty())
|
||||||
{
|
{
|
||||||
Document::Ptr pDoc = response.documents()[0];
|
Document::Ptr pDoc = response.documents()[0];
|
||||||
return pDoc->getInteger("ok") == 1;
|
return pDoc->getInteger("ok") == 1;
|
||||||
}
|
}
|
||||||
else throw Poco::ProtocolException("empty response for authenticate");
|
throw Poco::ProtocolException("empty response for authenticate");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -204,7 +206,10 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co
|
|||||||
Int32 conversationId = 0;
|
Int32 conversationId = 0;
|
||||||
std::string serverFirstMsg;
|
std::string serverFirstMsg;
|
||||||
|
|
||||||
if (response.documents().size() > 0)
|
if (response.documents().empty())
|
||||||
|
{
|
||||||
|
throw Poco::ProtocolException("empty response for saslStart");
|
||||||
|
}
|
||||||
{
|
{
|
||||||
Document::Ptr pDoc = response.documents()[0];
|
Document::Ptr pDoc = response.documents()[0];
|
||||||
if (pDoc->getInteger("ok") == 1)
|
if (pDoc->getInteger("ok") == 1)
|
||||||
@ -213,9 +218,11 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co
|
|||||||
serverFirstMsg = pPayload->toRawString();
|
serverFirstMsg = pPayload->toRawString();
|
||||||
conversationId = pDoc->get<Int32>("conversationId");
|
conversationId = pDoc->get<Int32>("conversationId");
|
||||||
}
|
}
|
||||||
else return false;
|
else
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else throw Poco::ProtocolException("empty response for saslStart");
|
|
||||||
|
|
||||||
std::map<std::string, std::string> kvm = parseKeyValueList(serverFirstMsg);
|
std::map<std::string, std::string> kvm = parseKeyValueList(serverFirstMsg);
|
||||||
const std::string serverNonce = kvm["r"];
|
const std::string serverNonce = kvm["r"];
|
||||||
@ -260,7 +267,10 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co
|
|||||||
|
|
||||||
std::string serverSecondMsg;
|
std::string serverSecondMsg;
|
||||||
connection.sendRequest(*pCommand, response);
|
connection.sendRequest(*pCommand, response);
|
||||||
if (response.documents().size() > 0)
|
if (response.documents().empty())
|
||||||
|
{
|
||||||
|
throw Poco::ProtocolException("empty response for saslContinue");
|
||||||
|
}
|
||||||
{
|
{
|
||||||
Document::Ptr pDoc = response.documents()[0];
|
Document::Ptr pDoc = response.documents()[0];
|
||||||
if (pDoc->getInteger("ok") == 1)
|
if (pDoc->getInteger("ok") == 1)
|
||||||
@ -268,9 +278,11 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co
|
|||||||
Binary::Ptr pPayload = pDoc->get<Binary::Ptr>("payload");
|
Binary::Ptr pPayload = pDoc->get<Binary::Ptr>("payload");
|
||||||
serverSecondMsg = pPayload->toRawString();
|
serverSecondMsg = pPayload->toRawString();
|
||||||
}
|
}
|
||||||
else return false;
|
else
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else throw Poco::ProtocolException("empty response for saslContinue");
|
|
||||||
|
|
||||||
Poco::HMACEngine<Poco::SHA1Engine> hmacSKey(saltedPassword);
|
Poco::HMACEngine<Poco::SHA1Engine> hmacSKey(saltedPassword);
|
||||||
hmacSKey.update(std::string("Server Key"));
|
hmacSKey.update(std::string("Server Key"));
|
||||||
@ -293,12 +305,12 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co
|
|||||||
.add<Binary::Ptr>("payload", new Binary);
|
.add<Binary::Ptr>("payload", new Binary);
|
||||||
|
|
||||||
connection.sendRequest(*pCommand, response);
|
connection.sendRequest(*pCommand, response);
|
||||||
if (response.documents().size() > 0)
|
if (!response.documents().empty())
|
||||||
{
|
{
|
||||||
Document::Ptr pDoc = response.documents()[0];
|
Document::Ptr pDoc = response.documents()[0];
|
||||||
return pDoc->getInteger("ok") == 1;
|
return pDoc->getInteger("ok") == 1;
|
||||||
}
|
}
|
||||||
else throw Poco::ProtocolException("empty response for saslContinue");
|
throw Poco::ProtocolException("empty response for saslContinue");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -312,7 +324,7 @@ Document::Ptr Database::queryBuildInfo(Connection& connection) const
|
|||||||
connection.sendRequest(*request, response);
|
connection.sendRequest(*request, response);
|
||||||
|
|
||||||
Document::Ptr buildInfo;
|
Document::Ptr buildInfo;
|
||||||
if ( response.documents().size() > 0 )
|
if ( !response.documents().empty() )
|
||||||
{
|
{
|
||||||
buildInfo = response.documents()[0];
|
buildInfo = response.documents()[0];
|
||||||
}
|
}
|
||||||
@ -353,7 +365,7 @@ Int64 Database::count(Connection& connection, const std::string& collectionName)
|
|||||||
Poco::MongoDB::ResponseMessage response;
|
Poco::MongoDB::ResponseMessage response;
|
||||||
connection.sendRequest(*countRequest, response);
|
connection.sendRequest(*countRequest, response);
|
||||||
|
|
||||||
if (response.documents().size() > 0)
|
if (!response.documents().empty())
|
||||||
{
|
{
|
||||||
Poco::MongoDB::Document::Ptr doc = response.documents()[0];
|
Poco::MongoDB::Document::Ptr doc = response.documents()[0];
|
||||||
return doc->getInteger("n");
|
return doc->getInteger("n");
|
||||||
@ -409,7 +421,7 @@ Document::Ptr Database::getLastErrorDoc(Connection& connection) const
|
|||||||
Poco::MongoDB::ResponseMessage response;
|
Poco::MongoDB::ResponseMessage response;
|
||||||
connection.sendRequest(*request, response);
|
connection.sendRequest(*request, response);
|
||||||
|
|
||||||
if (response.documents().size() > 0)
|
if (!response.documents().empty())
|
||||||
{
|
{
|
||||||
errorDoc = response.documents()[0];
|
errorDoc = response.documents()[0];
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user