Example #1
0
        /// <summary>
        /// Operation without transaction
        /// </summary>
        /// <param name="newPermissions"></param>
        /// <returns></returns>
        public IList <ValidationResult> SaveUserPermissions(IList <UserPermission> newPermissions)
        {
            IList <ValidationResult> validations = new List <ValidationResult>();

            foreach (var newPermission in newPermissions)
            {
                validations = _userPermissionRepository.Validate(newPermission);
                if (validations.Count > 0)
                {
                    return(validations);
                }

                _userPermissionRepository.Save(newPermission);
            }
            return(validations);
        }
Example #2
0
        /// <summary>
        /// 修改用户授权
        /// </summary>
        /// <param name="modifyUserPermission">用户授权修改信息</param>
        /// <returns>返回执行结果</returns>
        public Result Modify(ModifyUserPermissionParameter modifyUserPermission)
        {
            if (modifyUserPermission?.UserPermissions.IsNullOrEmpty() ?? true)
            {
                return(Result.FailedResult("没有指定任何要修改的用户授权信息"));
            }

            var userPermissions = modifyUserPermission.UserPermissions;

            #region 角色授权

            //用户绑定角色
            IEnumerable <long> userIds       = userPermissions.Select(c => c.UserId).Distinct();
            IQuery             userRoleQuery = QueryManager.Create <UserRoleEntity>(c => userIds.Contains(c.UserId));

            //角色授权
            IQuery rolePermissionQuery = QueryManager.Create <RolePermissionEntity>();
            rolePermissionQuery.EqualInnerJoin(userRoleQuery);

            IEnumerable <long> rolePermissionIds = rolePermissionRepository.GetList(rolePermissionQuery).Select(c => c.Item2.Id);

            #endregion

            //移除当前存在的授权数据
            userPermissionRepository.Remove(userPermissions, new ActivationOptions()
            {
                ForceExecute = true
            });
            var saveUserPermissions = new List <UserPermission>();
            //角色拥有但是用户显示禁用掉的授权
            var disablePermissions = userPermissions.Where(c => c.Disable && rolePermissionIds.Contains(c.PermissionId)).ToList();
            if (!disablePermissions.IsNullOrEmpty())
            {
                saveUserPermissions.AddRange(disablePermissions);
            }
            //用户单独授权的权限
            var enablePermissions = userPermissions.Where(c => !c.Disable && !rolePermissionIds.Contains(c.PermissionId)).ToList();
            if (!enablePermissions.IsNullOrEmpty())
            {
                saveUserPermissions.AddRange(enablePermissions);
            }
            if (!saveUserPermissions.IsNullOrEmpty())
            {
                userPermissionRepository.Save(saveUserPermissions);
            }
            return(Result.SuccessResult("修改成功"));
        }