0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-11-19 08:21:09 +01:00

modules/client/user/rooms: Support room account data.

This commit is contained in:
Jason Volk 2018-06-19 21:32:29 -06:00
parent 4b5545f844
commit 6d81f355dc
3 changed files with 214 additions and 18 deletions

View file

@ -12,28 +12,30 @@
using namespace ircd; using namespace ircd;
extern "C" void
room_account_data_get(const m::user &user,
const m::room &room,
const string_view &type,
const m::user::account_data_closure &closure);
extern "C" m::event::id::buf
room_account_data_set(const m::user &user,
const m::room &room,
const m::user &sender,
const string_view &type,
const json::object &value);
static resource::response static resource::response
put__account_data(client &client, put__account_data(client &client,
const resource::request &request, const resource::request &request,
const m::user::id &user_id, const m::user &user,
const m::room::id &room_id) const m::room &room_id);
{
if(request.parv.size() < 5)
throw m::NEED_MORE_PARAMS
{
"type required"
};
const string_view &type static resource::response
{ get__account_data(client &client,
request.parv[4] const resource::request &request,
}; const m::user &user,
const m::room &room);
return resource::response
{
client, http::OK
};
}
resource::response resource::response
put__rooms(client &client, put__rooms(client &client,
@ -70,3 +72,189 @@ put__rooms(client &client,
"/user/rooms/ command not found" "/user/rooms/ command not found"
}; };
} }
resource::response
get__rooms(client &client,
const resource::request &request,
const m::user::id &user_id)
{
if(request.parv.size() < 3)
throw m::NEED_MORE_PARAMS
{
"room_id required"
};
m::room::id::buf room_id
{
url::decode(request.parv[2], room_id)
};
if(request.parv.size() < 4)
throw m::NEED_MORE_PARAMS
{
"rooms command required"
};
const string_view &cmd
{
request.parv[3]
};
if(cmd == "account_data")
return get__account_data(client, request, user_id, room_id);
throw m::NOT_FOUND
{
"/user/rooms/ command not found"
};
}
resource::response
put__account_data(client &client,
const resource::request &request,
const m::user &user,
const m::room &room)
{
if(request.parv.size() < 5)
throw m::NEED_MORE_PARAMS
{
"type path parameter required"
};
char typebuf[256];
const auto &type
{
url::decode(request.parv[4], typebuf)
};
const json::object &value
{
request
};
const auto event_id
{
room_account_data_set(user, room, user, type, value)
};
return resource::response
{
client, http::OK
};
}
resource::response
get__account_data(client &client,
const resource::request &request,
const m::user &user,
const m::room &room)
{
if(request.parv.size() < 5)
throw m::NEED_MORE_PARAMS
{
"type path parameter required"
};
char typebuf[256];
const auto &type
{
url::decode(request.parv[4], typebuf)
};
room_account_data_get(user, room, type, [&client]
(const json::object &value)
{
resource::response
{
client, value
};
});
return {}; // responded from closure
}
constexpr string_view
room_account_data_type_prefix
{
"ircd.account_data"_sv
};
constexpr size_t
room_account_data_typebuf_size
{
m::room::id::MAX_SIZE + size(room_account_data_type_prefix)
};
static string_view
make_type(const mutable_buffer &out,
const m::room::id &room_id)
{
assert(size(out) >= room_account_data_typebuf_size);
string_view ret;
ret = strlcpy(out, room_account_data_type_prefix);
ret = strlcat(out, room_id);
return ret;
}
void
room_account_data_get(const m::user &user,
const m::room &room,
const string_view &user_type,
const m::user::account_data_closure &closure)
try
{
char typebuf[room_account_data_typebuf_size];
const string_view type
{
make_type(typebuf, room.room_id)
};
const m::user::room user_room
{
user
};
user_room.get(type, user_type, [&closure]
(const m::event &event)
{
const json::object &value
{
at<"content"_>(event)
};
closure(value);
});
}
catch(const m::NOT_FOUND &e)
{
throw m::NOT_FOUND
{
"Nothing about '%s' account_data for %s in room %s",
user_type,
string_view{user.user_id},
string_view{room.room_id}
};
}
m::event::id::buf
room_account_data_set(const m::user &user,
const m::room &room,
const m::user &sender,
const string_view &user_type,
const json::object &value)
{
char typebuf[room_account_data_typebuf_size];
const string_view type
{
make_type(typebuf, room.room_id)
};
const m::user::room user_room
{
user
};
return send(user_room, sender, type, user_type, value);
}

View file

@ -59,6 +59,9 @@ get_user(client &client, const resource::request &request)
if(cmd == "account_data") if(cmd == "account_data")
return get__account_data(client, request, user_id); return get__account_data(client, request, user_id);
if(cmd == "rooms")
return get__rooms(client, request, user_id);
throw m::NOT_FOUND throw m::NOT_FOUND
{ {
"/user command not found" "/user command not found"

View file

@ -66,6 +66,11 @@ post__openid(ircd::client &client,
// rooms.cc // rooms.cc
// //
ircd::resource::response
get__rooms(ircd::client &client,
const ircd::resource::request &request,
const ircd::m::user::id &user_id);
ircd::resource::response ircd::resource::response
put__rooms(ircd::client &client, put__rooms(ircd::client &client,
const ircd::resource::request &request, const ircd::resource::request &request,