Merge pull request #346 from erqan/leavegroup

improves on `leavegroup`
This commit is contained in:
miguelfreitas 2015-09-12 10:05:52 -03:00
commit 29b01b5d2d
2 changed files with 27 additions and 7 deletions

View File

@ -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]);

View File

@ -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();
} }