final String innerSubsite = subsite;
final PageManager innerPageManager = pageManager;
final String innerUserName = userName;
final User innerUser = user;
User powerUser = userManager.getUser(this.adminUser);
JetspeedException pe = (JetspeedException) JSSubject.doAsPrivileged(userManager.getSubject(powerUser), new PrivilegedAction()
{
public Object run()
{
try
{
if (innerSubsite != null)
{
innerUser.getSecurityAttributes().getAttribute(User.JETSPEED_USER_SUBSITE_ATTRIBUTE, true).setStringValue(innerSubsite);
userManager.updateUser(innerUser);
}
// create user's home folder
// deep copy from the default folder template tree, creating a deep-copy of the template
// in the new user's folder tree
Folder source = innerPageManager.getFolder(innerFolderTemplate);
innerPageManager.deepCopyFolder(source, innerSubsite, innerUserName);
Folder newFolder = pageManager.getFolder(innerSubsite);
newFolder.setTitle("Home Folder");
newFolder.setShortTitle("Home");
return null;
}
catch (SecurityException s1)
{
return s1;
}
catch (FolderNotFoundException e1)
{
return e1;
}
catch (InvalidFolderException e1)
{
return e1;
}
catch (NodeException e1)
{
return e1;
}
}
}, null);
if(pe != null)
{
// rollback user creation and cascade roles, groups, etc
try
{
if (userManager.getUser(userName) != null)
{
userManager.removeUser(userName);
}
}
catch (Exception e)
{
log.error("Registration Error: Failed to rollback user " + userName);
}
log.error("Registration Error: Failed to create user folders for " + userName + ", " + pe.toString());
throw pe;
}
}
catch (Exception e)