2018-04-05 03:12:51 +02:00
|
|
|
// 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 backfill"
|
|
|
|
};
|
|
|
|
|
|
|
|
resource
|
|
|
|
backfill_resource
|
|
|
|
{
|
|
|
|
"/_matrix/federation/v1/backfill/",
|
|
|
|
{
|
|
|
|
"federation backfill",
|
|
|
|
resource::DIRECTORY,
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-05-01 08:35:53 +02:00
|
|
|
static size_t
|
|
|
|
calc_limit(const resource::request &request);
|
|
|
|
|
|
|
|
resource::response
|
|
|
|
get__backfill(client &client,
|
|
|
|
const resource::request &request);
|
|
|
|
|
|
|
|
resource::method
|
|
|
|
method_get
|
|
|
|
{
|
|
|
|
backfill_resource, "GET", get__backfill,
|
|
|
|
{
|
|
|
|
method_get.VERIFY_ORIGIN
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-04-05 03:12:51 +02:00
|
|
|
conf::item<size_t>
|
|
|
|
backfill_limit_max
|
|
|
|
{
|
|
|
|
{ "name", "ircd.federation.backfill.limit.max" },
|
2018-05-01 08:35:53 +02:00
|
|
|
{ "default", 16384L },
|
2018-04-05 03:12:51 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
conf::item<size_t>
|
|
|
|
backfill_limit_default
|
|
|
|
{
|
|
|
|
{ "name", "ircd.federation.backfill.limit.default" },
|
|
|
|
{ "default", 64L },
|
|
|
|
};
|
|
|
|
|
2018-05-08 09:15:18 +02:00
|
|
|
conf::item<size_t>
|
|
|
|
backfill_flush_hiwat
|
|
|
|
{
|
|
|
|
{ "name", "ircd.federation.backfill.flush.hiwat" },
|
|
|
|
{ "default", 16384L },
|
|
|
|
};
|
|
|
|
|
2018-04-05 03:12:51 +02:00
|
|
|
resource::response
|
|
|
|
get__backfill(client &client,
|
2018-05-01 08:35:53 +02:00
|
|
|
const resource::request &request)
|
2018-04-05 03:12:51 +02:00
|
|
|
{
|
|
|
|
m::room::id::buf room_id
|
|
|
|
{
|
|
|
|
url::decode(request.parv[0], room_id)
|
|
|
|
};
|
|
|
|
|
|
|
|
m::event::id::buf event_id
|
|
|
|
{
|
|
|
|
request.query["v"]?
|
|
|
|
url::decode(request.query.at("v"), event_id):
|
|
|
|
m::head(room_id)
|
|
|
|
};
|
|
|
|
|
|
|
|
const size_t limit
|
|
|
|
{
|
|
|
|
calc_limit(request)
|
|
|
|
};
|
|
|
|
|
|
|
|
m::room::messages it
|
|
|
|
{
|
|
|
|
room_id, event_id
|
|
|
|
};
|
|
|
|
|
|
|
|
const unique_buffer<mutable_buffer> buf
|
|
|
|
{
|
2018-04-30 19:25:44 +02:00
|
|
|
96_KiB
|
2018-04-05 03:12:51 +02:00
|
|
|
};
|
|
|
|
|
2018-04-30 19:25:44 +02:00
|
|
|
resource::response::chunked response
|
2018-04-05 03:12:51 +02:00
|
|
|
{
|
2018-04-30 19:25:44 +02:00
|
|
|
client, http::OK
|
|
|
|
};
|
2018-04-05 03:12:51 +02:00
|
|
|
|
2018-05-08 09:15:18 +02:00
|
|
|
const auto flush{[&response]
|
2018-04-30 19:25:44 +02:00
|
|
|
(const const_buffer &buf)
|
2018-04-05 03:12:51 +02:00
|
|
|
{
|
2018-04-30 19:25:44 +02:00
|
|
|
response.write(buf);
|
|
|
|
return buf;
|
|
|
|
}};
|
|
|
|
|
2018-05-08 09:15:18 +02:00
|
|
|
json::stack out
|
|
|
|
{
|
|
|
|
buf, flush, size_t(backfill_flush_hiwat)
|
|
|
|
};
|
|
|
|
|
2018-04-30 19:25:44 +02:00
|
|
|
json::stack::object top{out};
|
|
|
|
json::stack::member pdus_m
|
|
|
|
{
|
|
|
|
top, "pdus"
|
2018-04-05 03:12:51 +02:00
|
|
|
};
|
2018-04-30 19:25:44 +02:00
|
|
|
|
|
|
|
json::stack::array pdus
|
|
|
|
{
|
|
|
|
pdus_m
|
|
|
|
};
|
|
|
|
|
|
|
|
size_t count{0};
|
|
|
|
for(; it && count < limit; ++count, --it)
|
|
|
|
pdus.append(*it);
|
|
|
|
|
|
|
|
return {};
|
2018-04-05 03:12:51 +02:00
|
|
|
}
|
|
|
|
|
2018-05-01 08:35:53 +02:00
|
|
|
static size_t
|
|
|
|
calc_limit(const resource::request &request)
|
2018-04-05 03:12:51 +02:00
|
|
|
{
|
2018-05-01 08:35:53 +02:00
|
|
|
const auto &limit
|
2018-04-05 03:12:51 +02:00
|
|
|
{
|
2018-05-01 08:35:53 +02:00
|
|
|
request.query["limit"]
|
|
|
|
};
|
|
|
|
|
|
|
|
if(!limit)
|
|
|
|
return size_t(backfill_limit_default);
|
|
|
|
|
|
|
|
size_t ret
|
|
|
|
{
|
|
|
|
lex_cast<size_t>(limit)
|
|
|
|
};
|
|
|
|
|
|
|
|
return std::min(ret, size_t(backfill_limit_max));
|
|
|
|
}
|