public void Authorize(string roleId, params string[] perIds)
        {
            //a.角色需要重新设置的权限ID集合。
            var listNewPerIds = perIds.ToList();
            //b.角色原有的授权信息。
            var listOldPers = _roleAuthorizeRepository.GetList(roleId);

            //c.删除角色新设置和原有授权信息集合中相同的记录。
            for (int i = listOldPers.Count - 1; i >= 0; i--)
            {
                if (listNewPerIds.Contains(listOldPers[i].ModuleId))
                {
                    listNewPerIds.Remove(listOldPers[i].ModuleId);
                    listOldPers.Remove(listOldPers[i]);
                }
            }
            //d.新集合中剩下的授权信息新增到数据库。
            listNewPerIds.ForEach((perId) =>
            {
                _roleAuthorizeRepository.Insert(new Sys_RoleAuthorize()
                {
                    RoleId     = roleId,
                    ModuleId   = perId,
                    Id         = Guid.NewGuid().ToString(),
                    CreateUser = OperatorProvider.Instance.Current.Account,
                    CreateTime = DateTime.Now
                });
            });
            //e.旧集合中剩下的授权信息从数据库中删除。
            listOldPers.ForEach((perObj) =>
            {
                _roleAuthorizeRepository.Delete(perObj);
            });
        }
Beispiel #2
0
 public void SubmitForm(RoleAuthorizeEntity entity, string keyValue)
 {
     if (!string.IsNullOrEmpty(keyValue))
     {
         entity.Modify(keyValue);
         service.Update(entity);
     }
     else
     {
         entity.Create();
         service.Insert(entity);
     }
 }
Beispiel #3
0
 /// <summary>
 /// 保存权限记录
 /// </summary>
 /// <param name="moduleEntity"></param>
 /// <param name="keyValue"></param>
 public void SubmitForm(RoleAuthorizeEntity roleAuthorizeEntity, string keyValue)
 {
     if (!string.IsNullOrEmpty(keyValue))
     {
         roleAuthorizeEntity.F_Id = keyValue;
         service.Update(roleAuthorizeEntity);
     }
     else
     {
         roleAuthorizeEntity.Create();
         service.Insert(roleAuthorizeEntity);
     }
 }