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:
parent
4b5545f844
commit
6d81f355dc
3 changed files with 214 additions and 18 deletions
|
@ -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);
|
||||||
|
}
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in a new issue