7#include <boost/redis/connection.hpp>
8#include <boost/asio/detached.hpp>
9#include <boost/describe.hpp>
10#include <boost/asio/consign.hpp>
11#include <boost/asio/use_awaitable.hpp>
15#if defined(BOOST_ASIO_HAS_CO_AWAIT)
17#include <boost/json/serialize.hpp>
18#include <boost/json/parse.hpp>
19#include <boost/json/value_from.hpp>
20#include <boost/json/value_to.hpp>
21#include <boost/redis/resp3/serialization.hpp>
23namespace asio = boost::asio;
24namespace resp3 = boost::redis::resp3;
25using namespace boost::describe;
41BOOST_DESCRIBE_STRUCT(user, (), (name, age, country))
44void boost_redis_to_bulk(std::string& to, user
const& u)
46 resp3::boost_redis_to_bulk(to, boost::json::serialize(boost::json::value_from(u)));
52 node_view
const& node,
53 boost::system::error_code&)
55 u = boost::json::value_to<user>(boost::json::parse(
node.value));
58auto co_main(config cfg) -> asio::awaitable<void>
60 auto ex =
co_await asio::this_coro::executor;
61 auto conn = std::make_shared<connection>(ex);
62 conn->async_run(cfg, {}, asio::consign(asio::detached, conn));
65 user
const u{
"Joao",
"58",
"Brazil"};
69 req.push(
"SET",
"json-key", u);
70 req.push(
"GET",
"json-key");
72 response<ignore_t, user> resp;
74 co_await conn->async_exec(req, resp);
79 <<
"Name: " << std::get<1>(resp).value().name <<
"\n"
80 <<
"Age: " << std::get<1>(resp).value().age <<
"\n"
81 <<
"Country: " << std::get<1>(resp).value().country <<
"\n";
A basic_connection that type erases the executor.
std::decay_t< decltype(std::ignore)> ignore_t
Type used to ignore responses.
basic_node< std::string > node
A node in the response tree that owns its data.
std::tuple< adapter::result< Ts >... > response
Response with compile-time size.
Configure parameters used by the connection classes.
A node in the response tree.