public Dictionary <string, SPRoleType> AddBasicSecurityGroups(SPWeb ew, string safeTitle, SPUser owner, SPListItem eI)
        {
            ew.AllowUnsafeUpdates = true;
            Dictionary <string, SPRoleType> pNewGroups = new Dictionary <string, SPRoleType>();

            string[] grps     = new[] { "Owner", "Member", "Visitor" };
            SPGroup  ownerGrp = null;
            //SPListItem eI = ew.Lists[base.ListUid].GetItemById(base.ItemID);
            var spUInfoList = ew.Site.RootWeb.Lists["User Information List"];

            foreach (string grp in grps)
            {
                string finalName = string.Empty;
                try
                {
                    if (eI.HasUniqueRoleAssignments)
                    {
                        var raColl = eI.RoleAssignments;
                        var groupAlreadyCreated = (from SPRoleAssignment roleAssignment in raColl
                                                   where roleAssignment.Member.Name.Contains(grp)
                                                   select roleAssignment.Member.ID).Any();
                        if (groupAlreadyCreated)
                        {
                            continue;
                        }
                    }
                    finalName = CoreFunctions.AddGroup(ew, safeTitle, grp, ew.CurrentUser, ew.CurrentUser, string.Empty);
                    spUInfoList.Items.GetItemById(ew.SiteGroups[finalName].ID).SystemUpdate();
                    ew.Update();
                    Thread.Sleep(1000);
                }
                catch (Exception ex)
                {
                    Trace.TraceWarning("Unexpected Permission error on AddBasicSecurityGroup: " + ex);
                }

                SPGroup    finalGrp = ew.SiteGroups[finalName];
                SPRoleType rType;
                switch (grp)
                {
                case "Owner":
                    ownerGrp       = finalGrp;
                    rType          = SPRoleType.Administrator;
                    finalGrp.Owner = owner;
                    finalGrp.AddUser(owner);
                    finalGrp.AllowMembersEditMembership = true;
                    finalGrp.Update();
                    ew.Update();
                    break;

                default:
                    rType          = SPRoleType.Reader;
                    finalGrp.Owner = ownerGrp;
                    finalGrp.Update();
                    ew.Update();
                    break;
                }
                Thread.Sleep(500);
                //AddNewItemLvlPerm(eI, ew, rType, finalGrp);
                pNewGroups.Add(finalGrp.Name, rType);
            }
            return(pNewGroups);
        }
Example #2
0
        public static Dictionary <string, SPRoleType> AddBasicSecurityToWorkspace(SPWeb eleWeb, string safeTitle, SPUser owner)
        {
            var safeGroupTitle = string.Empty;

            safeGroupTitle = CoreFunctions.GetSafeGroupTitle(safeTitle);

            eleWeb.AllowUnsafeUpdates = true;
            Dictionary <string, SPRoleType> pNewGroups = new Dictionary <string, SPRoleType>();

            string[] grps     = new[] { "Owner", "Member", "Visitor" };
            SPGroup  ownerGrp = null;

            // add groups and set group owners
            foreach (string grp in grps)
            {
                string  finalName = string.Empty;
                SPGroup testGrp   = null;
                try
                {
                    testGrp = eleWeb.SiteGroups[safeGroupTitle + " " + grp];
                }
                catch { }
                //Commented code is no longer use and commented to resolve Jira Id 2321
                //if (testGrp != null)
                //{
                //    finalName = testGrp.Name;
                //}
                //else
                //{
                try
                {
                    finalName = CoreFunctions.AddGroup(eleWeb, safeGroupTitle, grp, owner, eleWeb.CurrentUser, string.Empty);
                    eleWeb.Update();
                }
                catch { }
                //}

                SPGroup    finalGrp = eleWeb.SiteGroups[finalName];
                SPRoleType rType;
                switch (grp)
                {
                case "Owner":
                    ownerGrp       = finalGrp;
                    rType          = SPRoleType.Administrator;
                    finalGrp.Owner = owner;
                    finalGrp.AddUser(owner);
                    finalGrp.Update();
                    eleWeb.Update();
                    break;

                default:
                    rType          = SPRoleType.Reader;
                    finalGrp.Owner = ownerGrp;
                    finalGrp.Update();
                    eleWeb.Update();
                    break;
                }
                pNewGroups.Add(finalGrp.Name, rType);
            }

            // now set groups to become web's owner, member, visitor
            SPGroup group = null;
            SPRole  roll  = null;

            foreach (KeyValuePair <string, SPRoleType> g in pNewGroups)
            {
                if (g.Key.Contains("Owner"))
                {
                    group = eleWeb.SiteGroups[g.Key];
                    eleWeb.AssociatedOwnerGroup = group;
                    roll = eleWeb.Roles["Full Control"];
                    roll.AddGroup(group);
                }
                else if (g.Key.Contains("Member"))
                {
                    group = eleWeb.SiteGroups[g.Key];
                    eleWeb.AssociatedOwnerGroup = group;
                    roll = eleWeb.Roles["Contribute"];
                    roll.AddGroup(group);
                }
                else if (g.Key.Contains("Visitor"))
                {
                    group = eleWeb.SiteGroups[g.Key];
                    eleWeb.AssociatedOwnerGroup = group;
                    roll = eleWeb.Roles["Read"];
                    roll.AddGroup(group);
                }
            }

            eleWeb.Update();

            return(pNewGroups);
        }