mirror of
https://github.com/matrix-construct/construct
synced 2024-12-26 15:33:54 +01:00
modules: federation/federation library; move feds commands (prelim).
This commit is contained in:
parent
bfbeb388f2
commit
49a2cddc45
3 changed files with 162 additions and 118 deletions
|
@ -252,6 +252,7 @@ federation_federation_make_leave_la_SOURCES = federation/make_leave.cc
|
||||||
federation_federation_send_leave_la_SOURCES = federation/send_leave.cc
|
federation_federation_send_leave_la_SOURCES = federation/send_leave.cc
|
||||||
federation_federation_backfill_la_SOURCES = federation/backfill.cc
|
federation_federation_backfill_la_SOURCES = federation/backfill.cc
|
||||||
federation_federation_backfill_ids_la_SOURCES = federation/backfill_ids.cc
|
federation_federation_backfill_ids_la_SOURCES = federation/backfill_ids.cc
|
||||||
|
federation_federation_federation_la_SOURCES = federation/federation.cc
|
||||||
|
|
||||||
federation_module_LTLIBRARIES = \
|
federation_module_LTLIBRARIES = \
|
||||||
federation/federation_send.la \
|
federation/federation_send.la \
|
||||||
|
@ -270,6 +271,7 @@ federation_module_LTLIBRARIES = \
|
||||||
federation/federation_send_leave.la \
|
federation/federation_send_leave.la \
|
||||||
federation/federation_backfill.la \
|
federation/federation_backfill.la \
|
||||||
federation/federation_backfill_ids.la \
|
federation/federation_backfill_ids.la \
|
||||||
|
federation/federation_federation.la \
|
||||||
###
|
###
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
|
@ -3321,68 +3321,20 @@ console_cmd__feds__version(opt &out, const string_view &line)
|
||||||
"room_id",
|
"room_id",
|
||||||
}};
|
}};
|
||||||
|
|
||||||
const auto room
|
const auto room_id
|
||||||
{
|
{
|
||||||
m::room_id(param.at(0))
|
m::room_id(param.at(0))
|
||||||
};
|
};
|
||||||
|
|
||||||
struct req
|
using prototype = void (const m::room::id &,
|
||||||
:m::v1::version
|
std::ostream &);
|
||||||
{
|
|
||||||
char origin[256];
|
|
||||||
char buf[16_KiB];
|
|
||||||
|
|
||||||
req(m::v1::version::opts &&opts)
|
static m::import<prototype> feds__version
|
||||||
:m::v1::version{buf, std::move(opts)}
|
{
|
||||||
{}
|
"federation_federation", "feds__version"
|
||||||
};
|
};
|
||||||
|
|
||||||
std::list<req> reqs;
|
feds__version(room_id, out);
|
||||||
const m::room::origins origins{room};
|
|
||||||
origins.for_each([&out, &reqs]
|
|
||||||
(const string_view &origin)
|
|
||||||
{
|
|
||||||
m::v1::version::opts opts;
|
|
||||||
opts.remote = origin;
|
|
||||||
opts.dynamic = false; try
|
|
||||||
{
|
|
||||||
reqs.emplace_back(std::move(opts));
|
|
||||||
}
|
|
||||||
catch(const std::exception &e)
|
|
||||||
{
|
|
||||||
out << "! " << origin << " " << e.what() << std::endl;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
strlcpy(reqs.back().origin, origin);
|
|
||||||
});
|
|
||||||
|
|
||||||
auto all
|
|
||||||
{
|
|
||||||
ctx::when_all(begin(reqs), end(reqs))
|
|
||||||
};
|
|
||||||
|
|
||||||
all.wait(out.timeout, std::nothrow);
|
|
||||||
|
|
||||||
for(auto &req : reqs) try
|
|
||||||
{
|
|
||||||
if(req.wait(0ms, std::nothrow))
|
|
||||||
{
|
|
||||||
const auto code{req.get()};
|
|
||||||
const json::object &response{req};
|
|
||||||
out << "+ " << std::setw(40) << std::left << req.origin
|
|
||||||
<< " " << string_view{response}
|
|
||||||
<< std::endl;
|
|
||||||
}
|
|
||||||
else cancel(req);
|
|
||||||
}
|
|
||||||
catch(const std::exception &e)
|
|
||||||
{
|
|
||||||
out << "- " << std::setw(40) << std::left << req.origin
|
|
||||||
<< " " << e.what()
|
|
||||||
<< std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3391,7 +3343,7 @@ console_cmd__feds__event(opt &out, const string_view &line)
|
||||||
{
|
{
|
||||||
const params param{line, " ",
|
const params param{line, " ",
|
||||||
{
|
{
|
||||||
"event_id", "[room_id]"
|
"event_id"
|
||||||
}};
|
}};
|
||||||
|
|
||||||
const m::event::id event_id
|
const m::event::id event_id
|
||||||
|
@ -3399,71 +3351,15 @@ console_cmd__feds__event(opt &out, const string_view &line)
|
||||||
param.at(0)
|
param.at(0)
|
||||||
};
|
};
|
||||||
|
|
||||||
const m::room::id::buf room_id
|
using prototype = void (const m::event::id &,
|
||||||
{
|
std::ostream &);
|
||||||
param[1]? m::room_id(param.at(1)) : [&event_id]
|
|
||||||
{
|
|
||||||
const m::event::fetch event
|
|
||||||
{
|
|
||||||
event_id
|
|
||||||
};
|
|
||||||
|
|
||||||
return m::room::id::buf{at<"room_id"_>(event)};
|
static m::import<prototype> feds__event
|
||||||
}()
|
{
|
||||||
|
"federation_federation", "feds__event"
|
||||||
};
|
};
|
||||||
|
|
||||||
struct req
|
feds__event(event_id, out);
|
||||||
:m::v1::event
|
|
||||||
{
|
|
||||||
char origin[256];
|
|
||||||
char buf[96_KiB];
|
|
||||||
|
|
||||||
req(const m::event::id &event_id, m::v1::event::opts opts)
|
|
||||||
:m::v1::event{event_id, buf, std::move(opts)}
|
|
||||||
{}
|
|
||||||
};
|
|
||||||
|
|
||||||
std::list<req> reqs;
|
|
||||||
const m::room::origins origins{room_id};
|
|
||||||
origins.for_each([&out, &event_id, &reqs]
|
|
||||||
(const string_view &origin)
|
|
||||||
{
|
|
||||||
m::v1::event::opts opts;
|
|
||||||
opts.remote = origin;
|
|
||||||
opts.dynamic = false; try
|
|
||||||
{
|
|
||||||
reqs.emplace_back(event_id, std::move(opts));
|
|
||||||
}
|
|
||||||
catch(const std::exception &e)
|
|
||||||
{
|
|
||||||
out << "! " << origin << " " << e.what() << std::endl;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
strlcpy(reqs.back().origin, origin);
|
|
||||||
});
|
|
||||||
|
|
||||||
auto all
|
|
||||||
{
|
|
||||||
ctx::when_all(begin(reqs), end(reqs))
|
|
||||||
};
|
|
||||||
|
|
||||||
all.wait(out.timeout, std::nothrow);
|
|
||||||
|
|
||||||
for(auto &req : reqs) try
|
|
||||||
{
|
|
||||||
if(req.wait(0ms, std::nothrow))
|
|
||||||
{
|
|
||||||
const auto code{req.get()};
|
|
||||||
out << "+ " << req.origin << " " << http::status(code) << std::endl;
|
|
||||||
}
|
|
||||||
else cancel(req);
|
|
||||||
}
|
|
||||||
catch(const std::exception &e)
|
|
||||||
{
|
|
||||||
out << "- " << req.origin << " " << e.what() << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
146
modules/federation/federation.cc
Normal file
146
modules/federation/federation.cc
Normal file
|
@ -0,0 +1,146 @@
|
||||||
|
// Matrix Construct
|
||||||
|
//
|
||||||
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
||||||
|
// Copyright (C) 2016-2018 Jason Volk <jason@zemos.net>
|
||||||
|
//
|
||||||
|
// Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
// purpose with or without fee is hereby granted, provided that the above
|
||||||
|
// copyright notice and this permission notice is present in all copies. The
|
||||||
|
// full license for this software is available in the LICENSE file.
|
||||||
|
|
||||||
|
using namespace ircd;
|
||||||
|
|
||||||
|
mapi::header
|
||||||
|
IRCD_MODULE
|
||||||
|
{
|
||||||
|
"Federation :General Library and Utils"
|
||||||
|
};
|
||||||
|
|
||||||
|
extern "C" void
|
||||||
|
feds__version(const m::room::id &room_id, std::ostream &out)
|
||||||
|
{
|
||||||
|
struct req
|
||||||
|
:m::v1::version
|
||||||
|
{
|
||||||
|
char origin[256];
|
||||||
|
char buf[16_KiB];
|
||||||
|
|
||||||
|
req(m::v1::version::opts &&opts)
|
||||||
|
:m::v1::version{buf, std::move(opts)}
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
std::list<req> reqs;
|
||||||
|
const m::room::origins origins{room_id};
|
||||||
|
origins.for_each([&out, &reqs]
|
||||||
|
(const string_view &origin)
|
||||||
|
{
|
||||||
|
m::v1::version::opts opts;
|
||||||
|
opts.remote = origin;
|
||||||
|
opts.dynamic = false; try
|
||||||
|
{
|
||||||
|
reqs.emplace_back(std::move(opts));
|
||||||
|
}
|
||||||
|
catch(const std::exception &e)
|
||||||
|
{
|
||||||
|
out << "! " << origin << " " << e.what() << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
strlcpy(reqs.back().origin, origin);
|
||||||
|
});
|
||||||
|
|
||||||
|
auto all
|
||||||
|
{
|
||||||
|
ctx::when_all(begin(reqs), end(reqs))
|
||||||
|
};
|
||||||
|
|
||||||
|
all.wait(30s, std::nothrow);
|
||||||
|
|
||||||
|
for(auto &req : reqs) try
|
||||||
|
{
|
||||||
|
if(req.wait(1ms, std::nothrow))
|
||||||
|
{
|
||||||
|
const auto code{req.get()};
|
||||||
|
const json::object &response{req};
|
||||||
|
out << "+ " << std::setw(40) << std::left << req.origin
|
||||||
|
<< " " << string_view{response}
|
||||||
|
<< std::endl;
|
||||||
|
}
|
||||||
|
else cancel(req);
|
||||||
|
}
|
||||||
|
catch(const std::exception &e)
|
||||||
|
{
|
||||||
|
out << "- " << std::setw(40) << std::left << req.origin
|
||||||
|
<< " " << e.what()
|
||||||
|
<< std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" void
|
||||||
|
feds__event(const m::event::id &event_id, std::ostream &out)
|
||||||
|
{
|
||||||
|
const m::room::id::buf room_id{[&event_id]
|
||||||
|
{
|
||||||
|
const m::event::fetch event
|
||||||
|
{
|
||||||
|
event_id
|
||||||
|
};
|
||||||
|
|
||||||
|
return m::room::id::buf{at<"room_id"_>(event)};
|
||||||
|
}()};
|
||||||
|
|
||||||
|
struct req
|
||||||
|
:m::v1::event
|
||||||
|
{
|
||||||
|
char origin[256];
|
||||||
|
char buf[96_KiB];
|
||||||
|
|
||||||
|
req(const m::event::id &event_id, m::v1::event::opts opts)
|
||||||
|
:m::v1::event{event_id, buf, std::move(opts)}
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
std::list<req> reqs;
|
||||||
|
const m::room::origins origins{room_id};
|
||||||
|
origins.for_each([&out, &event_id, &reqs]
|
||||||
|
(const string_view &origin)
|
||||||
|
{
|
||||||
|
m::v1::event::opts opts;
|
||||||
|
opts.remote = origin;
|
||||||
|
opts.dynamic = false; try
|
||||||
|
{
|
||||||
|
reqs.emplace_back(event_id, std::move(opts));
|
||||||
|
}
|
||||||
|
catch(const std::exception &e)
|
||||||
|
{
|
||||||
|
out << "! " << origin << " " << e.what() << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
strlcpy(reqs.back().origin, origin);
|
||||||
|
});
|
||||||
|
|
||||||
|
auto all
|
||||||
|
{
|
||||||
|
ctx::when_all(begin(reqs), end(reqs))
|
||||||
|
};
|
||||||
|
|
||||||
|
all.wait(30s, std::nothrow);
|
||||||
|
|
||||||
|
for(auto &req : reqs) try
|
||||||
|
{
|
||||||
|
if(req.wait(1ms, std::nothrow))
|
||||||
|
{
|
||||||
|
const auto code{req.get()};
|
||||||
|
out << "+ " << req.origin << " " << http::status(code) << std::endl;
|
||||||
|
}
|
||||||
|
else cancel(req);
|
||||||
|
}
|
||||||
|
catch(const std::exception &e)
|
||||||
|
{
|
||||||
|
out << "- " << req.origin << " " << e.what() << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
Loading…
Reference in a new issue