[examples] cancel -> disconnect

Reviewers: korina

Reviewed By: korina

Differential Revision: https://repo.mireo.local/D26781
This commit is contained in:
Bruno Iljazovic
2023-11-30 14:36:41 +01:00
parent dfd4b41a4e
commit 3e1a8d1bb6
6 changed files with 31 additions and 27 deletions

View File

@@ -54,6 +54,7 @@ The following example illustrates a simple scenario of configuring a Client and
#include <iostream> #include <iostream>
#include <boost/asio/io_context.hpp> #include <boost/asio/io_context.hpp>
#include <boost/asio/detached.hpp>
#include <boost/asio/ip/tcp.hpp> #include <boost/asio/ip/tcp.hpp>
#include <async_mqtt5.hpp> #include <async_mqtt5.hpp>
@@ -73,7 +74,7 @@ int main() {
async_mqtt5::retain_e::no, async_mqtt5::publish_props {}, async_mqtt5::retain_e::no, async_mqtt5::publish_props {},
[&c](async_mqtt5::error_code ec) { [&c](async_mqtt5::error_code ec) {
std::cout << ec.message() << std::endl; std::cout << ec.message() << std::endl;
c.cancel(); // close the client c.async_disconnect(asio::detached); // disconnect and close the client
} }
); );

View File

@@ -4,6 +4,7 @@
#include <boost/asio/io_context.hpp> #include <boost/asio/io_context.hpp>
#include <boost/asio/ssl.hpp> #include <boost/asio/ssl.hpp>
#include <boost/asio/use_awaitable.hpp> #include <boost/asio/use_awaitable.hpp>
#include <boost/asio/as_tuple.hpp>
#include <boost/asio/ip/tcp.hpp> #include <boost/asio/ip/tcp.hpp>
@@ -13,6 +14,8 @@ namespace asio = boost::asio;
namespace async_mqtt5 { namespace async_mqtt5 {
constexpr auto use_nothrow_awaitable = asio::as_tuple(asio::use_awaitable);
template <typename StreamBase> template <typename StreamBase>
struct tls_handshake_type<asio::ssl::stream<StreamBase>> { struct tls_handshake_type<asio::ssl::stream<StreamBase>> {
static constexpr auto client = asio::ssl::stream_base::client; static constexpr auto client = asio::ssl::stream_base::client;
@@ -79,7 +82,7 @@ void publish_qos0_openssl_tls() {
retain_e::no, publish_props{}, retain_e::no, publish_props{},
[&c](error_code ec) { [&c](error_code ec) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -113,7 +116,7 @@ void publish_qos1_openssl_tls() {
[&c](error_code ec, reason_code rc, puback_props) { [&c](error_code ec, reason_code rc, puback_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -148,7 +151,7 @@ void publish_qos2_openssl_tls() {
[&c](error_code ec, reason_code rc, pubcomp_props) { [&c](error_code ec, reason_code rc, pubcomp_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -213,7 +216,7 @@ void subscribe_and_receive_openssl_tls(int num_receive) {
std::cout << "payload: " << payload << std::endl; std::cout << "payload: " << payload << std::endl;
if (i == num_receive - 1) if (i == num_receive - 1)
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
} }
@@ -253,19 +256,19 @@ void test_coro() {
} }
}); });
auto [codes, props] = co_await c.async_subscribe( auto [ec1, codes, props] = co_await c.async_subscribe(
topics, subscribe_props {}, asio::use_awaitable topics, subscribe_props {}, use_nothrow_awaitable
); );
std::cout << "subscribe reason_code: " << codes[0].message() << std::endl; std::cout << "subscribe reason_code: " << codes[0].message() << std::endl;
auto [topic, payload, rec_props] = co_await c.async_receive(asio::use_awaitable); auto [ec2, topic, payload, rec_props] = co_await c.async_receive(use_nothrow_awaitable);
std::cout << "topic: " << topic << std::endl; std::cout << "topic: " << topic << std::endl;
std::cout << "payload: " << payload << std::endl; std::cout << "payload: " << payload << std::endl;
asio::steady_timer timer(ioc); asio::steady_timer timer(ioc);
timer.expires_from_now(std::chrono::seconds(1)); timer.expires_from_now(std::chrono::seconds(1));
co_await timer.async_wait(asio::use_awaitable); co_await timer.async_wait(use_nothrow_awaitable);
c.cancel(); co_await c.async_disconnect(use_nothrow_awaitable);
co_return; co_return;
}, asio::detached); }, asio::detached);
@@ -277,6 +280,6 @@ void run_openssl_tls_examples() {
publish_qos0_openssl_tls(); publish_qos0_openssl_tls();
publish_qos1_openssl_tls(); publish_qos1_openssl_tls();
publish_qos2_openssl_tls(); publish_qos2_openssl_tls();
subscribe_and_receive_openssl_tls(1); subscribe_and_receive_openssl_tls(2);
test_coro(); test_coro();
} }

View File

@@ -27,7 +27,7 @@ void publish_qos0_tcp() {
retain_e::no, publish_props{}, retain_e::no, publish_props{},
[&c](error_code ec) { [&c](error_code ec) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -55,7 +55,7 @@ void publish_qos1_tcp() {
[&c](error_code ec, reason_code rc, puback_props) { [&c](error_code ec, reason_code rc, puback_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -82,7 +82,7 @@ void publish_qos2_tcp() {
[&c](error_code ec, reason_code rc, pubcomp_props) { [&c](error_code ec, reason_code rc, pubcomp_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -129,7 +129,7 @@ void subscribe_and_receive_tcp(int num_receive) {
std::cout << "payload: " << payload << std::endl; std::cout << "payload: " << payload << std::endl;
if (i == num_receive - 1) if (i == num_receive - 1)
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
} }
@@ -142,5 +142,5 @@ void run_tcp_examples() {
publish_qos0_tcp(); publish_qos0_tcp();
publish_qos1_tcp(); publish_qos1_tcp();
publish_qos2_tcp(); publish_qos2_tcp();
subscribe_and_receive_tcp(1); subscribe_and_receive_tcp(2);
} }

View File

@@ -32,7 +32,7 @@ void publish_qos0_websocket_tcp() {
retain_e::no, publish_props{}, retain_e::no, publish_props{},
[&c](error_code ec) { [&c](error_code ec) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -63,7 +63,7 @@ void publish_qos1_websocket_tcp() {
[&c](error_code ec, reason_code rc, puback_props) { [&c](error_code ec, reason_code rc, puback_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -94,7 +94,7 @@ void publish_qos2_websocket_tcp() {
[&c](error_code ec, reason_code rc, pubcomp_props) { [&c](error_code ec, reason_code rc, pubcomp_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -154,7 +154,7 @@ void subscribe_and_receive_websocket_tcp(int num_receive) {
std::cout << "payload: " << payload << std::endl; std::cout << "payload: " << payload << std::endl;
if (i == num_receive - 1) if (i == num_receive - 1)
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
} }
@@ -168,5 +168,5 @@ void run_websocket_tcp_examples() {
publish_qos0_websocket_tcp(); publish_qos0_websocket_tcp();
publish_qos1_websocket_tcp(); publish_qos1_websocket_tcp();
publish_qos2_websocket_tcp(); publish_qos2_websocket_tcp();
subscribe_and_receive_websocket_tcp(1); subscribe_and_receive_websocket_tcp(2);
} }

View File

@@ -94,7 +94,7 @@ void publish_qos0_websocket_tls() {
retain_e::no, publish_props{}, retain_e::no, publish_props{},
[&c](error_code ec) { [&c](error_code ec) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -130,7 +130,7 @@ void publish_qos1_websocket_tls() {
[&c](error_code ec, reason_code rc, puback_props) { [&c](error_code ec, reason_code rc, puback_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -166,7 +166,7 @@ void publish_qos2_websocket_tls() {
[&c](error_code ec, reason_code rc, pubcomp_props) { [&c](error_code ec, reason_code rc, pubcomp_props) {
std::cout << "error_code: " << ec.message() << std::endl; std::cout << "error_code: " << ec.message() << std::endl;
std::cout << "reason_code: " << rc.message() << std::endl; std::cout << "reason_code: " << rc.message() << std::endl;
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
@@ -231,7 +231,7 @@ void subscribe_and_receive_websocket_tls(int num_receive) {
std::cout << "payload: " << payload << std::endl; std::cout << "payload: " << payload << std::endl;
if (i == num_receive - 1) if (i == num_receive - 1)
c.cancel(); c.async_disconnect(asio::detached);
} }
); );
} }
@@ -245,5 +245,5 @@ void run_websocket_tls_examples() {
publish_qos0_websocket_tls(); publish_qos0_websocket_tls();
publish_qos1_websocket_tls(); publish_qos1_websocket_tls();
publish_qos2_websocket_tls(); publish_qos2_websocket_tls();
subscribe_and_receive_websocket_tls(1); subscribe_and_receive_websocket_tls(2);
} }

View File

@@ -169,7 +169,7 @@ private:
void complete_post(error_code ec, size_t num_topics) { void complete_post(error_code ec, size_t num_topics) {
_handler.complete_post( _handler.complete_post(
ec, std::vector<reason_code> { num_topics, reason_codes::empty }, suback_props {} ec, std::vector<reason_code> { num_topics, reason_codes::empty }, unsuback_props {}
); );
} }