Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,8 @@ jobs:
# older libzmq and without draft
- os: "ubuntu-22.04"
cppstd: "11"
cc: "gcc-9"
cxx: "g++-9"
cc: "gcc-11"
cxx: "g++-11"
drafts: "OFF"
libzmq: "4.2.0"
libzmqbuild: "pkgconfig"
Expand All @@ -38,8 +38,8 @@ jobs:
# coverage (gcc version should match gcov version)
- os: "ubuntu-22.04"
cppstd: "17"
cc: "gcc-9"
cxx: "g++-9"
cc: "gcc-11"
cxx: "g++-11"
drafts: "ON"
libzmq: "4.3.5"
libzmqbuild: "cmake"
Expand Down
1 change: 1 addition & 0 deletions tests/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ add_executable(
monitor.cpp
utilities.cpp
timers.cpp
curve.cpp
)

target_include_directories(unit_tests PUBLIC ${CATCH_MODULE_PATH})
Expand Down
30 changes: 30 additions & 0 deletions tests/curve.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
#include <catch2/catch_all.hpp>
#include <zmq.hpp>

TEST_CASE("curve_keypair", "[curve]")
{
auto [public_key, secret_key] = zmq::curve_keypair();
CHECK(!public_key.empty());
CHECK(!secret_key.empty());
}

TEST_CASE("curve_public_", "[curve]")
{
auto secret_key = "D:)Q[IlAW!ahhC2ac:9*A}h:p?([4%wOTJ%JR%cs";
auto public_key = zmq::curve_public(secret_key);
CHECK(public_key == "Yne@$w-vo<fVvi]a<NY6T1ed:M$fCG*[IaLV{hID");
}

TEST_CASE("z85_encode", "[curve]")
{
std::vector<uint8_t> data{1,2,3,4,5,6,7,8};
auto encoded = zmq::z85_encode(data);
CHECK(encoded.size() == std::string("0rJua1Qkhq").size());
CHECK(encoded == "0rJua1Qkhq");
}

TEST_CASE("z85_decode", "[curve]")
{
auto decoded = zmq::z85_decode("0rJua1Qkhq");
CHECK(decoded == std::vector<uint8_t>{1,2,3,4,5,6,7,8});
}
48 changes: 46 additions & 2 deletions zmq.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,7 @@

#include <cassert>
#include <cstring>
#include <cstdint>

#include <type_traits>
#include <algorithm>
Expand Down Expand Up @@ -539,7 +540,7 @@ class message_t
throw error_t();
memcpy(data(), data_, size_);
}

void rebuild(const std::string &str)
{
rebuild(str.data(), str.size());
Expand Down Expand Up @@ -2492,7 +2493,7 @@ class monitor_t
(void) addr_;
}

protected:
protected:
bool process_event(short events)
{
zmq::message_t eventMsg;
Expand Down Expand Up @@ -2874,6 +2875,49 @@ class timers

#endif // defined(ZMQ_CPP11) && defined(ZMQ_HAVE_TIMERS)

inline std::pair<std::string, std::string> curve_keypair()
{
char public_key_buffer[41];
char secret_key_buffer[41];
int rc = zmq_curve_keypair(public_key_buffer, secret_key_buffer);
if (rc == -1)
throw zmq::error_t();
return std::pair{public_key_buffer, secret_key_buffer};
}

inline std::string curve_public(const std::string& secret)
{
if (secret.size() != 40)
throw std::runtime_error("Invalid secret string size");
char public_key_buffer[41];
int rc = zmq_curve_public(public_key_buffer, secret.c_str());
if (rc == -1)
throw zmq::error_t();
return public_key_buffer;
}

inline std::string z85_encode(const std::vector<uint8_t>& data)
{
size_t buffer_size = data.size() * size_t{6} / size_t{5} + 1;
std::string buffer(buffer_size, '\0');
auto *result = zmq_z85_encode(buffer.data(), data.data(), data.size());
if (result == nullptr)
throw zmq::error_t();
while (buffer.back() == '\0')
buffer.pop_back();
return buffer;
}

inline std::vector<uint8_t> z85_decode(const std::string& encoded)
{
size_t dest_size = encoded.size() * size_t{4} / size_t{5};
std::vector<uint8_t> dest(dest_size);
auto *result = zmq_z85_decode(dest.data(), encoded.c_str());
if (result == nullptr)
throw zmq::error_t();
return dest;
}

} // namespace zmq

#endif // __ZMQ_HPP_INCLUDED__
Loading