mirror of
https://github.com/matrix-construct/construct
synced 2025-01-01 10:24:13 +01:00
ircd:Ⓜ️ Add linkage for user::presence;
modules/client/presence: reorg for linkage; minor cleanup.
This commit is contained in:
parent
e8fd7eebe0
commit
150543ae91
3 changed files with 111 additions and 57 deletions
|
@ -39,6 +39,8 @@ struct ircd::m::user
|
|||
bool is_active() const;
|
||||
bool is_password(const string_view &password) const noexcept;
|
||||
|
||||
event::id::buf presence(const string_view &, const string_view &status = {});
|
||||
|
||||
void password(const string_view &password);
|
||||
void activate(const json::members &contents = {});
|
||||
void deactivate(const json::members &contents = {});
|
||||
|
|
19
ircd/m/m.cc
19
ircd/m/m.cc
|
@ -266,6 +266,25 @@ ircd::m::leave_ircd_room()
|
|||
leave(my_room, me.user_id);
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// m/user.h
|
||||
//
|
||||
|
||||
ircd::m::event::id::buf
|
||||
ircd::m::user::presence(const string_view &presence,
|
||||
const string_view &status_msg)
|
||||
{
|
||||
using prototype = event::id::buf (const id &, const string_view &, const string_view &);
|
||||
|
||||
static import<prototype> function
|
||||
{
|
||||
"client_presence", "set__user_presence_status"
|
||||
};
|
||||
|
||||
return function(user_id, presence, status_msg);
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// m/room.h
|
||||
|
|
|
@ -26,6 +26,10 @@ presence_resource
|
|||
}
|
||||
};
|
||||
|
||||
//
|
||||
// put
|
||||
//
|
||||
|
||||
const string_view
|
||||
valid_states[]
|
||||
{
|
||||
|
@ -33,63 +37,30 @@ valid_states[]
|
|||
};
|
||||
|
||||
static bool
|
||||
valid_state(const string_view &state)
|
||||
{
|
||||
return std::any_of(begin(valid_states), end(valid_states), [&state]
|
||||
(const string_view &valid)
|
||||
{
|
||||
return state == valid;
|
||||
});
|
||||
}
|
||||
valid_state(const string_view &state);
|
||||
|
||||
extern "C" m::event::id::buf
|
||||
set__user_presence_status(const m::user::id &user_id,
|
||||
const string_view &presence,
|
||||
const string_view &status_msg);
|
||||
|
||||
static resource::response
|
||||
put__presence_status(client &client,
|
||||
const resource::request &request,
|
||||
const m::user::id &user_id)
|
||||
const m::user::id &user_id);
|
||||
|
||||
static resource::response
|
||||
put__presence(client &client,
|
||||
const resource::request &request);
|
||||
|
||||
resource::method
|
||||
method_put
|
||||
{
|
||||
const string_view &presence
|
||||
presence_resource, "PUT", put__presence,
|
||||
{
|
||||
unquote(request.at("presence"))
|
||||
};
|
||||
|
||||
if(!valid_state(presence))
|
||||
throw m::UNSUPPORTED
|
||||
{
|
||||
"That presence state is not supported"
|
||||
};
|
||||
|
||||
const string_view &status_msg
|
||||
{
|
||||
trunc(unquote(request["status_msg"]), 390)
|
||||
};
|
||||
|
||||
json::iov content;
|
||||
const json::iov::push _presence[]
|
||||
{
|
||||
{ content, { "presence", presence } },
|
||||
{ content, { "user_id", user_id } },
|
||||
};
|
||||
|
||||
const json::iov::set_if _status_msg
|
||||
{
|
||||
content, !empty(status_msg),
|
||||
{
|
||||
"status_msg", status_msg
|
||||
}
|
||||
};
|
||||
|
||||
const m::user::room user_room
|
||||
{
|
||||
user_id
|
||||
};
|
||||
|
||||
send(user_room, user_id, "m.presence", content);
|
||||
|
||||
return resource::response
|
||||
{
|
||||
client, http::OK
|
||||
};
|
||||
}
|
||||
method_put.REQUIRES_AUTH
|
||||
}
|
||||
};
|
||||
|
||||
resource::response
|
||||
put__presence(client &client,
|
||||
|
@ -134,14 +105,76 @@ put__presence(client &client,
|
|||
};
|
||||
}
|
||||
|
||||
resource::method
|
||||
method_put
|
||||
resource::response
|
||||
put__presence_status(client &client,
|
||||
const resource::request &request,
|
||||
const m::user::id &user_id)
|
||||
{
|
||||
presence_resource, "PUT", put__presence,
|
||||
const string_view &presence
|
||||
{
|
||||
method_put.REQUIRES_AUTH
|
||||
}
|
||||
};
|
||||
unquote(request.at("presence"))
|
||||
};
|
||||
|
||||
const string_view &status_msg
|
||||
{
|
||||
trunc(unquote(request["status_msg"]), 390)
|
||||
};
|
||||
|
||||
set__user_presence_status(request.user_id, presence, status_msg);
|
||||
|
||||
return resource::response
|
||||
{
|
||||
client, http::OK
|
||||
};
|
||||
}
|
||||
|
||||
m::event::id::buf
|
||||
set__user_presence_status(const m::user::id &user_id,
|
||||
const string_view &presence,
|
||||
const string_view &status_msg)
|
||||
{
|
||||
if(!valid_state(presence))
|
||||
throw m::UNSUPPORTED
|
||||
{
|
||||
"That presence state is not supported"
|
||||
};
|
||||
|
||||
json::iov content;
|
||||
const json::iov::push _presence[]
|
||||
{
|
||||
{ content, { "presence", presence } },
|
||||
{ content, { "user_id", user_id } },
|
||||
};
|
||||
|
||||
const json::iov::set_if _status_msg
|
||||
{
|
||||
content, !empty(status_msg),
|
||||
{
|
||||
"status_msg", status_msg
|
||||
}
|
||||
};
|
||||
|
||||
const m::user::room user_room
|
||||
{
|
||||
user_id
|
||||
};
|
||||
|
||||
return send(user_room, user_id, "m.presence", content);
|
||||
}
|
||||
|
||||
bool
|
||||
valid_state(const string_view &state)
|
||||
{
|
||||
return std::any_of(begin(valid_states), end(valid_states), [&state]
|
||||
(const string_view &valid)
|
||||
{
|
||||
return state == valid;
|
||||
});
|
||||
}
|
||||
|
||||
//
|
||||
// get
|
||||
//
|
||||
|
||||
static resource::response
|
||||
get__presence_status(client &client,
|
||||
|
|
Loading…
Reference in a new issue