diff options
| author | Linus Jahn <lnj@kaidan.im> | 2022-09-14 20:16:59 +0200 |
|---|---|---|
| committer | Linus Jahn <lnj@kaidan.im> | 2022-09-14 22:28:32 +0200 |
| commit | f48aedd89fc7654a8435367aa50a124724dfcd0c (patch) | |
| tree | e30432f1f0a5625eb89b0bb3b32cbe8a9031fa81 | |
| parent | 50be94233ad615ef8061e344f4123745714339c7 (diff) | |
| download | qxmpp-f48aedd89fc7654a8435367aa50a124724dfcd0c.tar.gz | |
BitsOfBinaryData: Add fromByteArray() utility function
It automatically hashes the data and creates a content ID.
| -rw-r--r-- | src/base/QXmppBitsOfBinaryData.cpp | 23 | ||||
| -rw-r--r-- | src/base/QXmppBitsOfBinaryData.h | 2 | ||||
| -rw-r--r-- | tests/qxmppbitsofbinaryiq/tst_qxmppbitsofbinaryiq.cpp | 30 |
3 files changed, 55 insertions, 0 deletions
diff --git a/src/base/QXmppBitsOfBinaryData.cpp b/src/base/QXmppBitsOfBinaryData.cpp index 1592a2e5..6f9226de 100644 --- a/src/base/QXmppBitsOfBinaryData.cpp +++ b/src/base/QXmppBitsOfBinaryData.cpp @@ -41,6 +41,29 @@ QXmppBitsOfBinaryDataPrivate::QXmppBitsOfBinaryDataPrivate() /// /// +/// Creates bits of binary data from a QByteArray. +/// +/// This hashes the data to generate a content ID. The MIME type is not set. +/// +/// \note This blocks while hashing the data. You may want to run this via QtConcurrent or a +/// QThreadPool to run this on for large amounts of data. +/// +/// \since QXmpp 1.5 +/// +QXmppBitsOfBinaryData QXmppBitsOfBinaryData::fromByteArray(QByteArray data) +{ + QXmppBitsOfBinaryContentId cid; + cid.setHash(QCryptographicHash::hash(data, QCryptographicHash::Sha1)); + cid.setAlgorithm(QCryptographicHash::Sha1); + + QXmppBitsOfBinaryData bobData; + bobData.d->cid = std::move(cid); + bobData.d->data = std::move(data); + + return bobData; +} + +/// /// Default constructor /// QXmppBitsOfBinaryData::QXmppBitsOfBinaryData() diff --git a/src/base/QXmppBitsOfBinaryData.h b/src/base/QXmppBitsOfBinaryData.h index 3e5ad20b..e0a0226c 100644 --- a/src/base/QXmppBitsOfBinaryData.h +++ b/src/base/QXmppBitsOfBinaryData.h @@ -18,6 +18,8 @@ class QXmppBitsOfBinaryContentId; class QXMPP_EXPORT QXmppBitsOfBinaryData { public: + static QXmppBitsOfBinaryData fromByteArray(QByteArray data); + QXmppBitsOfBinaryData(); QXmppBitsOfBinaryData(const QXmppBitsOfBinaryData &); QXmppBitsOfBinaryData(QXmppBitsOfBinaryData &&); diff --git a/tests/qxmppbitsofbinaryiq/tst_qxmppbitsofbinaryiq.cpp b/tests/qxmppbitsofbinaryiq/tst_qxmppbitsofbinaryiq.cpp index 8f71efb0..1fa2896f 100644 --- a/tests/qxmppbitsofbinaryiq/tst_qxmppbitsofbinaryiq.cpp +++ b/tests/qxmppbitsofbinaryiq/tst_qxmppbitsofbinaryiq.cpp @@ -18,6 +18,7 @@ private slots: void testResult(); void testOtherSubelement(); void testIsBobIq(); + Q_SLOT void fromByteArray(); }; void tst_QXmppBitsOfBinaryIq::testBasic() @@ -190,5 +191,34 @@ void tst_QXmppBitsOfBinaryIq::testIsBobIq() QCOMPARE(QXmppBitsOfBinaryIq::isBitsOfBinaryIq(doc.documentElement()), false); } +void tst_QXmppBitsOfBinaryIq::fromByteArray() +{ + auto data = QByteArray::fromBase64( + "iVBORw0KGgoAAAANSUhEUgAAALQAAAA8BAMAAAA9AI20AAAAG1BMVEX///8AAADf39+" + "/v79/f39fX1+fn58/Pz8fHx/8ACGJAAAACXBIWXMAAA7EAAAOxAGVKw4bAAADS0lEQV" + "RYhe2WS3MSQRCAYTf7OKY1kT0CxsRjHmh5BENIjqEk6pHVhFzdikqO7CGyP9t59Ox2z" + "y6UeWBVqugLzM70Nz39mqnV1lIWgBWiYXV0BYfNZ0mvwypds1r62vH/gf76ZL/88Qlc" + "41zeAnQrpx5H3z1Npfr5ovmHusa9SpRiNNIOcdrto6PJ5LLfb5bp9zM+VDq/vptxDEa" + "a1sql9I3R5KhtfQsA5gNCWYyulV3TyTUDdfL56BvdDl4x7RiybDq9uBgxh1TTPUHDvA" + "qNQb+LpT5sWehxJZKKcU2MZ6sDE7PMgW2mdlBGdy6ODe6fJFdMI+us95dNqftDMdwU6" + "+MhpuTS9slcy5TFAcwq0Jt6qssJMTQGp4BGURlmSsNoo5oHL4kqc66NdkDO75mIfCxm" + "RAlvHxMLdcb7JONavMJbttXXKoMSneYu3OQTlwkUh4mNayi6js55/2VcsZOQfXIYelz" + "xLcntEGc3WVCsCORJVCc5r0ajAcq+EO1Q0oPm7n7+X/3jEReGdL6qT7Ml6FCjY+quJC" + "r+D01f6BG0SaHG56ZG32DnY2jcEV1+pU0kxTaEwaGcekN7jyu50U/TV4q6YeieyiNTu" + "klDKZLukyjKVNwotCUB3B0XO1WjHT3c0DHSO2zACwut8GOiljJIHaJsrlof/fpWNzGM" + "os6TgIY0hZNpJshzSi4igOhy3cl4qK+YgnqHkAYcZEgdW6/HyrEK7afoY7RCFzArLl2" + "LLDdrdmmHZfROajwIDfWj8yQG+rzwlA3WvdJiMHtjUekiNrp1oCbmyZDEyKROGjFVDr" + "PRzlkR9UAfG/OErnPxrop5BwpoEpXQorq2zcGxbnBJndx8Bh0yljGiGv0B4E8+YP3Xp" + "2rGydZNy4csW8W2pIvWhvijoujRJ0luXsoymV+8AXvE9HjII72+oReS6OfomHe3xWg/" + "f2coSbDa1XZ1CvGMjy1nH9KBl83oPnQKi+vAXKLjCrRvvT2WCMkPmSFbquiVuTH1qjv" + "p4j/u7CWyI5/Hn3KAaJJ90eP0Zp1Kjets4WPaElkxheF7cpBESzXuIdLwyFjSub07tB" + "6JjxH3DGiu+zwHHimdtFsMvKqG/nBxm2TwbvyU6LWs5RnJX4dSldg3QhDLAAAAAElFT" + "kSuQmCC"); + auto size = data.size(); + auto bobData = QXmppBitsOfBinaryData::fromByteArray(std::move(data)); + QCOMPARE(bobData.cid().toContentId(), QStringLiteral("sha1+5a4c38d44fc64805cbb2d92d8b208be13ff40c0f@bob.xmpp.org")); + QCOMPARE(bobData.data().size(), size); +} + QTEST_MAIN(tst_QXmppBitsOfBinaryIq) #include "tst_qxmppbitsofbinaryiq.moc" |
