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 == "getspamposts" && n > 2) ConvertTo<boost::int64_t>(params[2]);
|
||||||
if (strMethod == "search" && 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 == "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 > 1) ConvertTo<boost::int64_t>(params[1]);
|
||||||
if (strMethod == "newgroupinvite" && n > 3) ConvertTo<Array>(params[3]);
|
if (strMethod == "newgroupinvite" && n > 3) ConvertTo<Array>(params[3]);
|
||||||
if (strMethod == "newgroupdescription" && n > 1) ConvertTo<boost::int64_t>(params[1]);
|
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)
|
Value listgroups(const Array& params, bool fHelp)
|
||||||
{
|
{
|
||||||
if (fHelp || params.size() != 0)
|
if (fHelp || params.size() > 2 )
|
||||||
throw runtime_error(
|
throw runtime_error(
|
||||||
"listgroups\n"
|
"listgroups [username] [list_only_ignored=false]\n"
|
||||||
"get list of group chats");
|
"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;
|
Array ret;
|
||||||
|
|
||||||
LOCK(cs_twister);
|
if (strUsername.size() && !m_users.count(strUsername))
|
||||||
map<string,GroupChat>::const_iterator i;
|
throw JSONRPCError(RPC_INTERNAL_ERROR, "unknown user");
|
||||||
for (i = m_groups.begin(); i != m_groups.end(); ++i) {
|
|
||||||
ret.push_back(i->first);
|
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;
|
return ret;
|
||||||
@ -3850,6 +3868,7 @@ Value leavegroup(const Array& params, bool fHelp)
|
|||||||
|
|
||||||
m_users[strUser].m_directmsg.erase(strGroupAlias);
|
m_users[strUser].m_directmsg.erase(strGroupAlias);
|
||||||
m_users[strUser].m_ignoreGroups.insert(strGroupAlias);
|
m_users[strUser].m_ignoreGroups.insert(strGroupAlias);
|
||||||
|
m_groups[strGroupAlias].m_members.erase(strUser);
|
||||||
|
|
||||||
return Value();
|
return Value();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user