0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-12-28 00:14:07 +01:00

modules/console: Add compose send cmd.

This commit is contained in:
Jason Volk 2018-05-30 10:05:23 -07:00
parent 7471417091
commit 411d637c84

View file

@ -2762,6 +2762,79 @@ console_cmd__compose__commit(opt &out, const string_view &line)
return true; return true;
} }
bool
console_cmd__compose__send(opt &out, const string_view &line)
{
const params param{line, " ",
{
"remote", "[id]"
}};
const net::hostport remote
{
param.at(0)
};
const int &id
{
param.at<int>(1, -1)
};
std::vector<json::value> pduv;
if(id > -1)
pduv.emplace_back(compose.at(id));
else
for(size_t i(0); i < compose.size(); ++i)
pduv.emplace_back(compose.at(i));
const auto txn
{
m::txn::create(pduv)
};
thread_local char idbuf[128];
const auto txnid
{
m::txn::create_id(idbuf, txn)
};
const unique_buffer<mutable_buffer> bufs
{
16_KiB
};
m::v1::send::opts opts;
opts.remote = remote;
m::v1::send request
{
txnid, const_buffer{txn}, bufs, std::move(opts)
};
request.wait(out.timeout);
const auto code
{
request.get()
};
const json::object response{request};
const m::v1::send::response resp
{
response
};
resp.for_each_pdu([&]
(const m::event::id &event_id, const json::object &error)
{
out << remote << " ->" << txnid << " " << event_id << " ";
if(empty(error))
out << http::status(code) << std::endl;
else
out << string_view{error} << std::endl;
});
return true;
}
int int
console_command_numeric(opt &out, const string_view &line) console_command_numeric(opt &out, const string_view &line)
{ {