1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-11 05:17:41 +03:00

Feature #1742: chgrp does not delete the user from the previous group

This allows users to use the chgrp to change their own primary
group to one of the secondary ones
This commit is contained in:
Carlos Martín 2013-08-23 18:37:50 +02:00
parent d0b28bc90a
commit 913a96f7e8

View File

@ -317,6 +317,8 @@ void UserChown::request_execute(xmlrpc_c::paramList const& paramList,
int rc; int rc;
bool remove_old_group;
string ngname; string ngname;
string uname; string uname;
@ -399,8 +401,17 @@ void UserChown::request_execute(xmlrpc_c::paramList const& paramList,
user->set_group(ngid,ngname); user->set_group(ngid,ngname);
user->add_group(ngid); // The user is removed from the old group only if the new group is not a
user->del_group(old_gid); // secondary one
rc = user->add_group(ngid);
remove_old_group = (rc == 0);
if (remove_old_group)
{
user->del_group(old_gid);
}
upool->update(user); upool->update(user);
@ -426,15 +437,18 @@ void UserChown::request_execute(xmlrpc_c::paramList const& paramList,
// ------------- Updates old group removing the user --------------------- // ------------- Updates old group removing the user ---------------------
group = gpool->get(old_gid, true); if (remove_old_group)
if( group != 0 )
{ {
group->del_user(oid); group = gpool->get(old_gid, true);
gpool->update(group); if( group != 0 )
{
group->del_user(oid);
group->unlock(); gpool->update(group);
group->unlock();
}
} }
success_response(oid, att); success_response(oid, att);