Beispiel #1
0
        /// <summary>
        /// 授予角色的权限
        /// </summary>
        /// <param name="userInfo">用户</param>
        /// <param name="roleId">角色主键</param>
        /// <param name="grantPermissionId">授予权限数组</param>
        /// <returns>数据主键</returns>
        public string GrantRolePermissionById(BaseUserInfo userInfo, string roleId, string grantPermissionId)
        {
            var result = string.Empty;

            var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod());

            ServiceUtil.ProcessUserCenterReadDb(userInfo, parameter, (dbHelper) =>
            {
                var manager = new BasePermissionManager(dbHelper, userInfo);
                // 小心异常,检查一下参数的有效性
                if (grantPermissionId != null)
                {
                    result = manager.GrantRole(userInfo.SystemCode, roleId, grantPermissionId);
                }
            });

            return(result);
        }
Beispiel #2
0
        /// <summary>
        /// 授予角色的权限
        /// </summary>
        /// <param name="userInfo">用户</param>
        /// <param name="roleIds">角色主键数组</param>
        /// <param name="grantPermissionIds">授予权限数组</param>
        /// <returns>影响的行数</returns>
        public int GrantRolePermissions(BaseUserInfo userInfo, string[] roleIds, string[] grantPermissionIds)
        {
            var result = 0;

            var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod());

            ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) =>
            {
                var tableName = userInfo.SystemCode + "Permission";
                var manager   = new BasePermissionManager(dbHelper, userInfo, tableName);
                // 小心异常,检查一下参数的有效性
                if (roleIds != null && grantPermissionIds != null)
                {
                    result += manager.GrantRole(userInfo.SystemCode, roleIds, grantPermissionIds);
                }
            });

            return(result);
        }
        /// <summary>
        /// 给角色权限
        /// </summary>
        /// <param name="userInfo">用户</param>
        /// <param name="roleName">角色名</param>
        /// <param name="permissionCode">权限编号</param>
        /// <returns>主键</returns>
        public string GrantRolePermission(BaseUserInfo userInfo, string roleName, string permissionCode)
        {
            var result = string.Empty;

            var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod());

            ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) =>
            {
                var roleId       = BaseRoleManager.GetIdByCodeByCache(userInfo.SystemCode, roleName);
                var permissionId = new BaseModuleManager().GetIdByCodeByCache(userInfo.SystemCode, permissionCode);
                if (!string.IsNullOrEmpty(roleId) && !string.IsNullOrEmpty(permissionId))
                {
                    var rolePermissionManager = new BasePermissionManager(dbHelper, userInfo);
                    result = rolePermissionManager.GrantRole(userInfo.SystemCode, roleId, permissionId);
                }
            });

            return(result);
        }