From 29b2c3a7b7399cc0d1c63b7b67b3e23cd45f3d5e Mon Sep 17 00:00:00 2001 From: Matej Kenda Date: Mon, 25 Nov 2024 14:27:46 +0100 Subject: [PATCH] chore(MongoDB): Mark some old wire protocol functions as deprecated. (#4782) --- MongoDB/include/Poco/MongoDB/Cursor.h | 3 +- MongoDB/include/Poco/MongoDB/Database.h | 4 +- MongoDB/include/Poco/MongoDB/DeleteRequest.h | 3 +- MongoDB/include/Poco/MongoDB/UpdateRequest.h | 3 +- MongoDB/src/Database.cpp | 46 ++++++++++++-------- 5 files changed, 34 insertions(+), 25 deletions(-) diff --git a/MongoDB/include/Poco/MongoDB/Cursor.h b/MongoDB/include/Poco/MongoDB/Cursor.h index 6339bc290..ffd8d8c89 100644 --- a/MongoDB/include/Poco/MongoDB/Cursor.h +++ b/MongoDB/include/Poco/MongoDB/Cursor.h @@ -26,8 +26,7 @@ namespace Poco { namespace MongoDB { -//class [[deprecated]] Cursor; -class Cursor; +class POCO_DEPRECATED("Use new wire protocol") Cursor; class MongoDB_API Cursor: public Document /// Cursor is an helper class for querying multiple documents. diff --git a/MongoDB/include/Poco/MongoDB/Database.h b/MongoDB/include/Poco/MongoDB/Database.h index 350c55cae..5d7b947bd 100644 --- a/MongoDB/include/Poco/MongoDB/Database.h +++ b/MongoDB/include/Poco/MongoDB/Database.h @@ -81,7 +81,7 @@ public: /// Creates a QueryRequest to count the given collection. /// The collectionname must not contain the database name. (old wire protocol) - //[[deprecated]] + POCO_DEPRECATED("Use new wire protocol") Poco::SharedPtr createDeleteRequest(const std::string& collectionName) const; /// Creates a DeleteRequest to delete documents in the given collection. /// The collectionname must not contain the database name. (old wire protocol) @@ -96,7 +96,7 @@ public: /// Creates a QueryRequest. (old wire protocol) /// The collectionname must not contain the database name. - //[[deprecated]] + POCO_DEPRECATED("Use new wire protocol") Poco::SharedPtr createUpdateRequest(const std::string& collectionName) const; /// Creates an UpdateRequest. (old wire protocol) /// The collectionname must not contain the database name. diff --git a/MongoDB/include/Poco/MongoDB/DeleteRequest.h b/MongoDB/include/Poco/MongoDB/DeleteRequest.h index 0226df5f2..dfd1b3e57 100644 --- a/MongoDB/include/Poco/MongoDB/DeleteRequest.h +++ b/MongoDB/include/Poco/MongoDB/DeleteRequest.h @@ -26,8 +26,7 @@ namespace Poco { namespace MongoDB { -//class [[deprecated]] DeleteRequest; -class DeleteRequest; +//class POCO_DEPRECATED("Use new wire protocol") DeleteRequest; class MongoDB_API DeleteRequest: public RequestMessage /// A DeleteRequest is used to delete one ore more documents from a database. diff --git a/MongoDB/include/Poco/MongoDB/UpdateRequest.h b/MongoDB/include/Poco/MongoDB/UpdateRequest.h index e7315c1ba..7dbb7e2af 100644 --- a/MongoDB/include/Poco/MongoDB/UpdateRequest.h +++ b/MongoDB/include/Poco/MongoDB/UpdateRequest.h @@ -26,8 +26,7 @@ namespace Poco { namespace MongoDB { -//class [[deprecated]] UpdateRequest; -class UpdateRequest; +//class POCO_DEPRECATED("Use new wire protocol") UpdateRequest; class MongoDB_API UpdateRequest: public RequestMessage /// This request is used to update a document in a database diff --git a/MongoDB/src/Database.cpp b/MongoDB/src/Database.cpp index ecd2ffd19..ff20bd7a0 100644 --- a/MongoDB/src/Database.cpp +++ b/MongoDB/src/Database.cpp @@ -81,7 +81,7 @@ namespace std::string digestToBinaryString(Poco::DigestEngine& engine) { Poco::DigestEngine::Digest d = engine.digest(); - return std::string(reinterpret_cast(&d[0]), d.size()); + return { reinterpret_cast(&d[0]), d.size() }; } std::string digestToHexString(Poco::DigestEngine& engine) @@ -116,7 +116,7 @@ namespace } return digestToHexString(md5); } -} +} // namespace Database::Database(const std::string& db): @@ -152,14 +152,16 @@ bool Database::authCR(Connection& connection, const std::string& username, const ResponseMessage 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]; if (pDoc->getInteger("ok") != 1) return false; nonce = pDoc->get("nonce", ""); if (nonce.empty()) throw Poco::ProtocolException("no nonce received"); } - else throw Poco::ProtocolException("empty response for getnonce"); std::string credsDigest = hashCredentials(username, password); @@ -177,12 +179,12 @@ bool Database::authCR(Connection& connection, const std::string& username, const .add("key", key); connection.sendRequest(*pCommand, response); - if (response.documents().size() > 0) + if (!response.documents().empty()) { Document::Ptr pDoc = response.documents()[0]; 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; 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]; if (pDoc->getInteger("ok") == 1) @@ -213,9 +218,11 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co serverFirstMsg = pPayload->toRawString(); conversationId = pDoc->get("conversationId"); } - else return false; + else + { + return false; + } } - else throw Poco::ProtocolException("empty response for saslStart"); std::map kvm = parseKeyValueList(serverFirstMsg); const std::string serverNonce = kvm["r"]; @@ -260,7 +267,10 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co std::string serverSecondMsg; 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]; if (pDoc->getInteger("ok") == 1) @@ -268,9 +278,11 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co Binary::Ptr pPayload = pDoc->get("payload"); serverSecondMsg = pPayload->toRawString(); } - else return false; + else + { + return false; + } } - else throw Poco::ProtocolException("empty response for saslContinue"); Poco::HMACEngine hmacSKey(saltedPassword); hmacSKey.update(std::string("Server Key")); @@ -293,12 +305,12 @@ bool Database::authSCRAM(Connection& connection, const std::string& username, co .add("payload", new Binary); connection.sendRequest(*pCommand, response); - if (response.documents().size() > 0) + if (!response.documents().empty()) { Document::Ptr pDoc = response.documents()[0]; 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); Document::Ptr buildInfo; - if ( response.documents().size() > 0 ) + if ( !response.documents().empty() ) { buildInfo = response.documents()[0]; } @@ -353,7 +365,7 @@ Int64 Database::count(Connection& connection, const std::string& collectionName) Poco::MongoDB::ResponseMessage response; connection.sendRequest(*countRequest, response); - if (response.documents().size() > 0) + if (!response.documents().empty()) { Poco::MongoDB::Document::Ptr doc = response.documents()[0]; return doc->getInteger("n"); @@ -409,7 +421,7 @@ Document::Ptr Database::getLastErrorDoc(Connection& connection) const Poco::MongoDB::ResponseMessage response; connection.sendRequest(*request, response); - if (response.documents().size() > 0) + if (!response.documents().empty()) { errorDoc = response.documents()[0]; }