0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-08-31 13:55:19 +02:00

modules/client/sync: Add highlight count to sync; reintegrate notification count.

This commit is contained in:
Jason Volk 2018-09-14 06:21:19 -07:00
parent b1cd9edcd2
commit a7dbc8e882
2 changed files with 85 additions and 15 deletions

View file

@ -350,20 +350,41 @@ ircd::m::sync::longpoll::sync_room(client &client,
m::receipt::read(last_read_buf, room, args.request.user_id) m::receipt::read(last_read_buf, room, args.request.user_id)
}; };
const auto notes const auto last_read_idx
{ {
last_read && json::get<"event_id"_>(event)? last_read && json::get<"event_id"_>(event)?
m::count_since(room, last_read, at<"event_id"_>(event)): index(last_read):
0UL 0UL
}; };
const auto current_idx
{
last_read_idx?
index(at<"event_id"_>(event)):
0UL
};
const auto notes
{
last_read_idx?
notification_count(room, last_read_idx, current_idx):
json::undefined_number
};
const auto highlights
{
last_read_idx?
highlight_count(room, args.request.user_id, last_read_idx, current_idx):
json::undefined_number
};
const json::members body const json::members body
{ {
{ "account_data", json::members{} }, { "account_data", json::members{} },
{ "unread_notifications", { "unread_notifications",
{ {
{ "highlight_count", int64_t(0) }, { "highlight_count", highlights },
{ "notification_count", long(notes) }, { "notification_count", notes },
}}, }},
{ "ephemeral", { "ephemeral",
{ {
@ -433,7 +454,7 @@ ircd::m::sync::linear::handle(client &client,
for(auto &p : r) for(auto &p : r)
{ {
const auto &room_id{p.first}; const m::room::id &room_id{p.first};
auto &vec{p.second}; auto &vec{p.second};
std::vector<std::string> timeline; std::vector<std::string> timeline;
@ -458,13 +479,27 @@ ircd::m::sync::linear::handle(client &client,
m::receipt::read(last_read_buf, room_id, sp.user) m::receipt::read(last_read_buf, room_id, sp.user)
}; };
const auto notes const auto last_read_idx
{ {
last_read? last_read?
m::count_since(m::room::id{room_id}, index(last_read), sp.current): index(last_read):
0UL 0UL
}; };
const auto notes
{
last_read_idx?
notification_count(room_id, last_read_idx, sp.current):
json::undefined_number
};
const auto highlights
{
last_read_idx?
highlight_count(room_id, sp.user, last_read_idx, sp.current):
json::undefined_number
};
const string_view prev_batch const string_view prev_batch
{ {
!timeline.empty()? !timeline.empty()?
@ -490,8 +525,8 @@ ircd::m::sync::linear::handle(client &client,
}}, }},
{ "unread_notifications", { "unread_notifications",
{ {
{ "highlight_count", int64_t(0) }, { "highlight_count", highlights },
{ "notification_count", long(notes) }, { "notification_count", notes },
}}, }},
}; };
@ -1111,22 +1146,32 @@ ircd::m::sync::polylog::room_account_data(shortpoll &sp,
}); });
} }
void void
ircd::m::sync::polylog::room_unread_notifications(shortpoll &sp, ircd::m::sync::polylog::room_unread_notifications(shortpoll &sp,
json::stack::object &out, json::stack::object &out,
const m::room &room) const m::room &room)
{ {
m::event::id::buf last_read_buf; m::event::id::buf last_read_buf;
const m::event::id last_read const auto last_read
{ {
m::receipt::read(last_read_buf, room, sp.user) m::receipt::read(last_read_buf, room, sp.user)
}; };
if(!last_read)
return;
const auto last_read_idx
{
index(last_read)
};
// highlight_count // highlight_count
json::stack::member json::stack::member
{ {
out, "highlight_count", json::value{0L} out, "highlight_count", json::value
{
highlight_count(room, sp.user, last_read_idx, sp.current)
}
}; };
// notification_count // notification_count
@ -1134,9 +1179,31 @@ ircd::m::sync::polylog::room_unread_notifications(shortpoll &sp,
{ {
out, "notification_count", json::value out, "notification_count", json::value
{ {
last_read? notification_count(room, last_read_idx, sp.current)
long(m::count_since(room, index(last_read), sp.current)):
0L
} }
}; };
} }
long
ircd::m::sync::highlight_count(const room &r,
const user &u,
const event::idx &a,
const event::idx &b)
{
using proto = size_t (const user &, const room &, const event::idx &, const event::idx &);
static mods::import<proto> count
{
"m_user", "highlighted_count__between"
};
return count(u, r, a, b);
}
long
ircd::m::sync::notification_count(const room &room,
const event::idx &a,
const event::idx &b)
{
return m::count_since(room, a, b);
}

View file

@ -14,6 +14,9 @@ namespace ircd::m::sync
struct stats; struct stats;
struct shortpoll; struct shortpoll;
static long notification_count(const room &, const event::idx &a, const event::idx &b);
static long highlight_count(const room &, const user &, const event::idx &a, const event::idx &b);
static resource::response handle_get(client &, const resource::request &); static resource::response handle_get(client &, const resource::request &);
extern resource::method method_get; extern resource::method method_get;
extern const string_view description; extern const string_view description;