/** * Add the given group in Silverpeas * * @param ddManager * @param group * @param onlyInSilverpeas * @return * @throws AdminException */ public String addGroup(DomainDriverManager ddManager, Group group, boolean onlyInSilverpeas) throws AdminException { if (group == null || !StringUtil.isDefined(group.getName())) { if (group != null) { SynchroReport.error( "GroupManager.addGroup()", "Problème lors de l'ajout du groupe " + group.getSpecificId() + " dans la base, ce groupe n'a pas de nom", null); } return ""; } try { ddManager.getOrganizationSchema(); // Create group in specific domain (if onlyInSilverpeas is not true) // if domainId=-1 then group is a silverpeas organization if (!onlyInSilverpeas) { String specificId; if (group.getDomainId() != null) { specificId = ddManager.createGroup(group); group.setSpecificId(specificId); } } // Create the group node in Silverpeas GroupRow gr = group2GroupRow(group); if (gr.superGroupId != -1) { SynchroReport.info( "GroupManager.addGroup()", "Ajout du groupe " + group.getName() + " (père=" + getGroup(ddManager, group.getSuperGroupId()).getSpecificId() + ") dans la table ST_Group", null); } else { // pas de père SynchroReport.info( "GroupManager.addGroup()", "Ajout du groupe " + group.getName() + " (groupe racine) dans la table ST_Group...", null); } ddManager.getOrganization().group.createGroup(gr); String sGroupId = idAsString(gr.id); // index group information ddManager.indexGroup(gr); // Create the links group_user in Silverpeas SynchroReport.info( "GroupManager.addGroup()", "Inclusion des utilisateurs directement associés au groupe " + group.getName() + " (table ST_Group_User_Rel)", null); String[] asUserIds = group.getUserIds(); int nUserAdded = 0; for (String asUserId : asUserIds) { if (StringUtil.isDefined(asUserId)) { ddManager.getOrganization().group.addUserInGroup(idAsInt(asUserId), idAsInt(sGroupId)); nUserAdded++; } } SynchroReport.info( "GroupManager.addGroup()", nUserAdded + " utilisateurs ajoutés au groupe " + group.getName() + " dans la base", null); return sGroupId; } catch (Exception e) { SynchroReport.error( "GroupManager.addGroup()", "problème lors de l'ajout du groupe " + group.getName() + " - " + e.getMessage(), null); throw new AdminException( "GroupManager.addGroup", SilverpeasException.ERROR, "admin.EX_ERR_ADD_GROUP", "group name: '" + group.getName() + "'", e); } finally { ddManager.releaseOrganizationSchema(); } }