mirror of
https://github.com/twisterarmy/twister-core.git
synced 2025-01-25 14:04:27 +00:00
commit
29b01b5d2d
@ -1350,6 +1350,7 @@ Array RPCConvertValues(const std::string &strMethod, const std::vector<std::stri
|
||||
if (strMethod == "getspamposts" && n > 2) ConvertTo<boost::int64_t>(params[2]);
|
||||
if (strMethod == "search" && n > 2) ConvertTo<boost::int64_t>(params[2]);
|
||||
if (strMethod == "search" && n > 3) ConvertTo<Object>(params[3]);
|
||||
if (strMethod == "listgroups" && n > 1) ConvertTo<bool>(params[1]);
|
||||
if (strMethod == "newgroupinvite" && n > 1) ConvertTo<boost::int64_t>(params[1]);
|
||||
if (strMethod == "newgroupinvite" && n > 3) ConvertTo<Array>(params[3]);
|
||||
if (strMethod == "newgroupdescription" && n > 1) ConvertTo<boost::int64_t>(params[1]);
|
||||
|
@ -3650,17 +3650,35 @@ Value creategroup(const Array& params, bool fHelp)
|
||||
|
||||
Value listgroups(const Array& params, bool fHelp)
|
||||
{
|
||||
if (fHelp || params.size() != 0)
|
||||
if (fHelp || params.size() > 2 )
|
||||
throw runtime_error(
|
||||
"listgroups\n"
|
||||
"get list of group chats");
|
||||
"listgroups [username] [list_only_ignored=false]\n"
|
||||
"get list of group chats\n"
|
||||
"if username is given, it will return list of user's groups.");
|
||||
|
||||
string strUsername = (params.size() > 0 ? params[0].get_str() : "");
|
||||
bool onlyIgnored = (params.size() > 1 ? params[1].get_bool() : false);
|
||||
|
||||
Array ret;
|
||||
|
||||
LOCK(cs_twister);
|
||||
map<string,GroupChat>::const_iterator i;
|
||||
for (i = m_groups.begin(); i != m_groups.end(); ++i) {
|
||||
ret.push_back(i->first);
|
||||
if (strUsername.size() && !m_users.count(strUsername))
|
||||
throw JSONRPCError(RPC_INTERNAL_ERROR, "unknown user");
|
||||
|
||||
if (onlyIgnored)
|
||||
{
|
||||
LOCK(cs_twister);
|
||||
BOOST_FOREACH(string const &strGroup, m_users[strUsername].m_ignoreGroups)
|
||||
ret.push_back(strGroup);
|
||||
}
|
||||
else
|
||||
{
|
||||
LOCK(cs_twister);
|
||||
map<string,GroupChat>::const_iterator i;
|
||||
for (i = m_groups.begin(); i != m_groups.end(); ++i) {
|
||||
if (strUsername.size() && !i->second.m_members.count(strUsername))
|
||||
continue;
|
||||
ret.push_back(i->first);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
@ -3850,6 +3868,7 @@ Value leavegroup(const Array& params, bool fHelp)
|
||||
|
||||
m_users[strUser].m_directmsg.erase(strGroupAlias);
|
||||
m_users[strUser].m_ignoreGroups.insert(strGroupAlias);
|
||||
m_groups[strGroupAlias].m_members.erase(strUser);
|
||||
|
||||
return Value();
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user